## 到解

# VHDL実習

## ゼロからわかるハードウェア記述言語

### 堀 桂太郎著

```
Port ( A : in sta_logic;
                                   when "01" => F <= A(1);
0000" => LED <= "00000011";
                                                                 B: in std_logic;
0001" => LED <= "10011111" :
                                   when "10" => F <= A(2);
                                                                 B I: in std logic;
0010" => LED <= "00100101"
                                   when "11" => F <= A(3)
                                                                 D : out std logic;
0011" => LED <= "00001101"
                                       n others => null ;
                                                                 B O : out std logic);
0100" => LED <= "10011001"
                                                          end rei3 6;
0101" => LED <= "01001001"
0110" => LED <= "01000001"
                                       ehavioral:
                                                           architecture Behavioral of rei3 6
0111" => LED <= "00011011"
                                                           signal SUB : std logic_vector(1
                                         EXILINX®
1000" => LED <= "00000001"
                                                           begin
1001" => LED <= "00001001"
                                      CoolRunner-II
                                                           SUB <= ('0' & A) - ('0' & B) - ( '0'
1010" => LED <= "00010001"
                                                           D <= SUB(0);
1011" => LED <= "11000001"
                                                           B 0 <= SUB(1);
1100" => LED <= "01100011
                                                           end Behavioral:
1101" => LED <= "10000101"
1110" => LED <= "01100001"
                                                 library IEEE;
|1111" => LED <= "01110001" ADTERA ...
                                                 use IEEE.STD_LOGIC_1164.ALL;
thers => null
                                                 use IEEE STD LOGIC_ARITH.ALL;
                                                 USE IEEE.STD LOGIC UNSIGNED ALL;
                                              CoolRunner-II
vioral: library IEEE:
                                                 entity rei3_10 is
Port ( A : in std_logic_vector(3 downto 0
      use IEEE.STD LOGIC 11
      use IBEE.STD LOGIC
                                                         S: in std_logic_vector(1 downto 0
      use IEEE.STD LOGIC U
                                                          F: out std_logic);
                                                 end rei3_10;
      entity rei3_4 is
         Port (A: in std_logic;
                                                 architecture Behavioral of rei3 10 is
             B: in std logic;
                                                 begin
            C_I : in std_logic;
                                                  process(A.S)
```

#### ■著者紹介

堀 桂太郎 (ほり・けいたろう) 明石工業高等専門学校助教授 博士 (工学)

写真提供:メメックジャパン株式会社 カバーデザイン: CELLENT JAPAN

|  |  |  | 1 |
|--|--|--|---|
|  |  |  |   |
|  |  |  |   |
|  |  |  |   |
|  |  |  |   |

| _ |  |  |  |
|---|--|--|--|
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |
|   |  |  |  |

## 図解

## VHDL実習

### ゼロからわかるハードウェア記述言語

### 堀 桂太郎著

```
"0010" => LEUL
                                                                     D. Out Sto_010
"0011" => LED <= "00001101"
"0100" => LED <= "10011001"
                                           others => null ;
                                                                     B_O : out std_logic):
                                                              end rei3_6;
"0101" => LED <= "01001001
"0110" => LED <= "01000001
"0111" => LED <= "00011011
                                                              architecture Behavioral of rei3 6
                                                              signal SUB : std_logic_vector(1)
                                            XILINX*
"1000" => LED
                                                              begin
"1001" => LED <= "00001001
                                         CoolRunner-II
                                                               SUB <= ('0' & A) - ('0' & B) = ( '0'
"1010" => LED
                                                              D <= SUB(0);
1011 - LED <= "1100
                                                              B_O \leftarrow SUB(1);
"[100" == LED <= "0110001
                                                              end Behavioral:
"1101" > LED <= "1000010"
"1110" => LED <= "01100001"
                                                    library IEEE;
"ITTL" => LED <= "01110001"
                                                    use IEEE.STD LOGIC 116 ALL:
                                                    use IEEE STD LOGIC_ARITH ALL
                                                    USE IEEE STD LOGIC UNSIGNED ALL
                                                  CoolRunner-II
        brary IEEE
                                                    entity rei3_10 is
        Use ISEE.STD LOGIC
        USE EE.STD_LOGIC
                                                       Port ( A : in std_logic_vector(3 downto 0
                                                             S: in std_logic_vector(1 downto 0
        USE IEEE.STD LOGIC
                                                             F : out std_logic);
                                                    end rei3_10;
        entity rei3_4 is
                                                    architecture Behavioral of rel3 10 is
```

本書に掲載の会社名,システム名,製品名,ソフトウェア名 などは各社,各組織の商標または登録商標です。

■本書の無断複写は著作権法上での例外を除き禁じられています。 複写される場合は、その都度事前に(株)日本著作出版権管理システム (電話 03-3817-5670, FAX 03-3815-8199) の許諾を得て下さい。

#### まえがき

ディジタル回路の基礎を一通り学習された方は、シフトレジスタやカウンタなどを応用した回路を設計、製作できるようになっていることでしょう。この場合、従来では、図記号を用いた回路設計を行った後、必要な汎用ロジック IC などを用意してはんだごて片手に製作を行うという手順が一般的でした。しかし、現在では HDL (ハードウェア記述言語)を用いることで、あたかもプログラミングを行うかのような感覚で設計を行い、設計データを CPLD/FPGA デバイスに転送するだけで実際のディジタル回路ができあがります。つまり、自分専用の IC を 1 個からでも簡単に製作することができるようになったのです。簡単な組合せ回路から CPU などの高機能なディジタル回路でさえ CPLD/FPGA を用いて構成することが可能です。しかも、開発用ソフトウェアはフリーで入手することができます。この設計手法をマスターすることは、現代のディジタル回路設計技術者にとって不可欠な要素になっています。

本書は、はじめて HDL を学ぶ方々を対象に、広く普及している VHDL を取り上げ、図を多く用いたわかりやすい解説を心がけました。そして、実際の開発ツールの操作手順を説明しながら、読者が実習を行いながら学習を進められるように配慮しました。扱う内容は、基本的な重要事項に絞り、欲張りすぎないように注意しました。しかし、本書の内容をマスターするだけでも、多くのディジタル回路を VHDL で自在に設計できるようになることでしょう。その後に、読者の皆様がさらに意欲をもって学習を進めて頂ければたいへん嬉しく思います。ただし、VHDL や各種の開発ツールは、決して万能ではありません。また、VHDL による設計は、ソフトウェアではなく、ハードウェアを構成するための作業です。したがって、できあがる回路を常にイメージしながら設計を進めることが大切です。そのためには、ディジタル回路の基礎知識が土台になることを忘れないでください。本書が、VHDL マスターへ向けた最初の一歩を踏み出すための入門書としてお役に立つことを心より願っています。

最後になりましたが、本書執筆の機会を与えてくださった森北出版の森北博巳氏、ならびに編集でお世話になった石田昇司氏にこの場を借りて厚く御礼申し上げます。

2004年3月

著 者

<本書で扱ったソースファイルは、以下の HP から入手可能です>

☆森北出版の HP: http://www.morikita.co.jp/soft/78391/ ☆著者の HP: http://www.akashi.ac.jp/contents/Electric/hori/

### 目 次

| 第1章        | CPLD/FPGA の基礎 ······                                   | 1  |
|------------|--------------------------------------------------------|----|
| 1.1 デ      | *イジタル回路の設計手法                                           | 2  |
| 1.1.1      | 汎用ロジック IC を使用する方法 2                                    |    |
| 1.1.2      | CPU を使用する方法 4                                          |    |
| 1.1.3      | 専用 IC を使用する方法 7                                        |    |
|            | CPLD/FPGA を使用する方法 8                                    |    |
| 1.2 C      | PLD/FPGA ·····                                         | 13 |
| 1.2.1      | CPLD 13                                                |    |
|            | FPGA 15                                                |    |
| 1.3        | <b>~~ドウェア記述言語</b> ···································· | 17 |
| 1.3.1      | ハードウェア記述言語の種類 17                                       |    |
|            | ハードウェア記述言語を用いた設計手順 19                                  |    |
| 1.4 閉      | 発環境の概要                                                 | 21 |
| 1.4.1      | 開発に必要なツール 21                                           |    |
|            | 開発ツール 21                                               |    |
|            | シミュレータ 22                                              |    |
| 1.4.4      | ダウンロードケーブル 23<br>【1 ······                             |    |
| 演習問題       | 11                                                     | 26 |
| thir o als | 設計の流れ                                                  | 07 |
|            | ではいる。                                                  |    |
|            |                                                        | 28 |
|            | ターゲットデバイスの選定 28<br>CDLD のほ 21                          |    |
|            | CPLD の例 31                                             |    |
|            | 評価ボードの例 33<br>延装までの手順                                  | 24 |
|            | - (大)              | 34 |
|            | TL体設計 34<br>VHDLコードの記述 35                              |    |
|            | 論理合成 43                                                |    |
|            | 配置配線 47                                                |    |
|            | ダウンロード 53                                              |    |
|            | 評価ボードによる動作確認 55                                        |    |
|            | 作成された各種ファイル 56                                         |    |
|            | 2                                                      | 58 |
|            | 4                                                      |    |
| WEI-VA     | 3.2                                                    | 00 |
|            | 組合せ回路の設計                                               |    |
| 第3章        |                                                        | 59 |

| 3.1.2 | データ型 64                            |
|-------|------------------------------------|
| 3.1.3 | signal 文 67                        |
|       | HDL 文法の基礎 ······· 70               |
|       | process 文 70                       |
| 3.2.2 | if 文 71                            |
| 3.2.3 | case 文 74                          |
| 3.2.4 | 動作記述と構造記述 76                       |
|       | VHDLの演算子と予約語 77                    |
|       | 種の組合せ回路 79                         |
|       | 加算器と減算器 79                         |
| 3.3.2 | エンコーダとデコーダ 85                      |
| 3.3.3 | マルチプレクサとデマルチプレクサ 90                |
| 演習問題  | 13 94                              |
|       |                                    |
| 第4章   | 順序回路の設計                            |
| 4.1 7 | リップフロップの設計96                       |
| 4.1.1 | 非同期式と同期式 96                        |
| 4.1.2 | クロックの記述 97                         |
| 4.1.3 | D-FF 97                            |
| 4.1.4 | RS-FF 102                          |
| 4.1.5 | <i>JK</i> -FF 104                  |
| 4.1.6 | T-FF 107                           |
| 4.2 シ | フトレジスタの設計109                       |
| 4.2.1 | シリアルイン・パラレルアウトのシフトレジスタ 109         |
| 4.2.2 | パラレルイン・シリアルアウトのシフトレジスタ 114         |
| 4.3 カ | ウンタの設計118                          |
| 4.3.1 | 同期式 n 進カウンタ 118                    |
| 4.3.2 | カウンタの応用 122                        |
| 演習問題  | カウンタの応用 122<br><b>4</b> ·······126 |
|       |                                    |
|       | 階層設計                               |
| 5.1 階 | 層設計の基礎128                          |
| 5.1.1 | 階層設計とは 128                         |
|       | 階層設計の方法 129                        |
| 5.2 階 | 層設計の実習138                          |
| 5.2.1 | 10 秒カウンタの設計 138                    |
|       | 100 秒カウンタの設計 143                   |
| 演習問題  | <b>5</b> ·······147                |
|       |                                    |
|       | シミュレーションの <b>基礎 ······</b> 149     |
| 6.1 テ | ストベンチ150                           |
| 611   | テストベンチレけ 150                       |

| 6.1.2 テストベンチの書き方 151                        |
|---------------------------------------------|
| 6.2 シミュレーション実習155                           |
| 6.2.1 シミュレーションの手順 155                       |
| 6.2.2 順序回路のシミュレーション 161                     |
| <b>演習問題 6</b> ·······164                    |
|                                             |
| 第7章 開発ツール165                                |
| 7.1 ザイリンクス社の開発ツール166                        |
| 7.1.1 ISE WebPACK の動作環境 166                 |
| 7.1.2 ISE WebPACK の入手とインストール 167            |
| 7.2 アルテラ社の開発ツール177                          |
| 7.2.1 Quartus II Web Edition の動作環境 177      |
| 7.2.2 Quartus II Web Edition の入手とインストール 177 |
| 7.2.3 ライセンスの取得 181                          |
| 7.2.4 ライセンスの設定 184                          |
| 7.2.5 パラレルポート用ドライバの設定 186                   |
| 7.3 シミュレータの入手とインストール188                     |
| 7.3.1 MXE II Starter の入手とインストール 188         |
| 7.3.2 ライセンスの取得 191                          |
| 7.3.3 ライセンスの設定 192                          |
| 7.4 評価ボードの概要195                             |
| 7.4.1 HDL トレーナーの概要 195                      |
| 7.4.2 HDL トレーナー拡張キットの構成 200                 |
| 7.4.3 HDLトレーナーの入手方法 200                     |
|                                             |
| 付録 Verilog-HDL について                         |
| 付.1 Verilog-HDLの書き方 201                     |
| 付.2 Verilog-HDLの文法 202                      |
| 付.3 Verilog-HDLのコード例 204                    |
|                                             |
| 演習問題解答207                                   |
| 参考文献 ····································   |
| 索 引                                         |

- \*本書掲載の URL, 画面写真等はとくに記述がない限り 2004 年1月時点のものです。
- \*HDLトレーナーについてのユーザサポートはソリトンウェーブ社で行います。その他のソフトウェアなどについては各社にお問い合わせください。

## 第1章 CPLD/FPGAの基礎

ディジタル回路を設計する場合、これまでは、設計者が AND、OR、NOT などのゲート図記号を組合せて回路を設計していました。言い換えれば、TTL や C-MOS などの汎用ロジック IC を用いて回路を構成することが前提となっていたのです。しかし、現在では CPLD や FPGA とよばれるデバイスを使用することを前提とし、各種の開発用ソフトウェアを用いた設計が主流になっています。

この章では、目的のディジタル回路を実現するためのいくつかの方法を説明したあと、CPLD や FPGA とはどのようなデバイスか、またこのデバイスを用いた回路設計の流れについて解説します。新しいディジタル回路設計手法を用いた場合のさまざまな利点や注意事項について理解しましょう。さらに、開発に必要なハードウェアやソフトウェアについての基礎を学びましょう。



## 1.1

#### ディジタル回路の設計方法

目的のディジタル回路を実現するためには、いくつかの方法があります。ここでは、汎用ロジック IC を使用する方法、CPU を使用する方法、専用 IC を使用する方法、CPLD や FPGA を使用する方法について説明します。

#### ▶ 1.1.1 汎用ロジック IC を使用する方法

0

たとえば、電子サイコロを製作する場合を考えましょう。図 1.1 に示すように、7個の LED (発光ダイオード)をサイコロの目に見立てて配置します。押しボタンスイッチを押した (ON) 後に離す (OFF) と、LED がサイコロの  $1 \sim 6$  までのいずれかの目をランダムに表示するようにします。



図 1.1 LED 表示部

ディジタル回路の基礎を学んだことのある方ならば、たとえば、図 1.2 に示すような回路構成を考えることができるでしょう。6進カウンタ回路の出力をデコーダ回路でデコードして、LED の点灯を $1\sim6$  までのサイコロの目に対応させます。6進カウンタを高速で動作させれば、人間の感覚では LED の点灯状態(サイコロの日)を予測できませんから、6進カウンタの動作を止めた時点でのサイコロの目はランダムになっていると考えることができます。したがって、6進カウンタの動作を押しボタンスイッチで ON、OFF すればよいのです。押しボタンスイッチ ONで電子サイコロのスタート、OFF でストップ(ランダム表示)となります。



図 1.2 電子サイコロの回路構成例

発振回路は、同期式6進カウンタを高速に動作させるための方形波を発生します.

もしも、電子サイコロの回路構成が理解できない場合でも、雰囲気だけをつかんでもらえば結構です。

この回路を従来の方法で設計する場合には、図 1.3 に示すように、6 進カウンタ回路とデコーダ回路の動作を真理値表で表し、そこから得た論理式をカルノー図やクワイン・マクラスキー法



図 1.3 従来のディジタル回路設計の流れ



図 1.4 汎用ロジック IC を使用した電子サイコロ回路の例

などによって簡単化します. そして, AND, OR, NOT, フリップフロップ (FF) などの汎用ロジック IC を用いて回路を設計するのが一般的でした.

このような手順によって設計した回路例を図1.4、実際の製作例を図1.5に示します.



図 1.5 汎用ロジック IC を使用した電子サイコロの製作例

この回路では、74HC73 (JK-FF) など5個の汎用ロジックICを使用しました。このような従来法による設計では、実際の回路を製作して動作を確認し、エラーが見つかれば前の段階に戻って検証作業を行います(図1.3). 場合によっては、新たな汎用ロジックICを追加して回路を製作し直さなければならないこともあります。専用のプリント基板を製作している場合には、基板の作り直しも行わなければなりません。回路の規模が大きくなると、修正や変更の作業はより困難なものとなってしまいます。

#### ▶ 1.1.2 CPU を使用する方法

1971 年にインテル社の発表した世界初の CPU である i4004 は、ディジタル回路の世界に大きな革命をもたらしました(図 1.6).



図 1.6 i4004 (インテル株式会社)

CPU が発表されるまでは、IC を用途ごとに設計して製作していたため、一種類の IC を作る だけでも膨大な時間と費用が必要でした.しかし、CPUを使用すれば、ソフトウェア(プログ ラム)を変更することで目的の動作を実現することができるようになったのです。i4004 の発表 以降. CPU は汎用性の高い万能 IC として発展を続けています.

前に紹介した電子サイコロ回路の動作は、CPUを使って実現することもできます。たとえば、 安価で扱いの簡単な PIC マイコンを例に挙げましょう。 PIC マイコンは、マイクロチップテク ノロジー社の開発した高性能マイコンで、1個のパッケージに CPU やメモリ機能などを内蔵し ており、制御用として広く利用されています。図 1.7 に、PIC マイコンの外観例を示します。



図 1.7 PIC マイコンの外観例 (上が PIC16F84A)

PIC マイコンを使用して電子サイコロを製作する場合には、入出力ピンに押しボタンスイッチ や LED を接続して,ランダムなサイコロの目を表示するようなプログラムを与えます.図 1.8 に、CPU(マイコン)を用いた設計の流れを示します。この場合には、6進カウンタやデコーダ といったディジタル回路を意識する必要はありません。LED の表示を高速で1~6まで繰り返 し変化させ、押しボタンスイッチを離したときに、表示が停止するようにプログラムを作成すれ ばよいのです。



図 1.8 CPU (マイコン) を用いた設計の流れ

図 1.9 に PIC マイコン (PIC16F84A) を使用した電子サイコロの回路、リスト 1.1 に C 言語に よるプログラム例を示します.



図 1.9 PIC マイコンを使用した電子サイコロ回路の例

```
// リスト1
// PIC による電子サイコロのプログラム
#include
         <16F84A.h>
#use
         delay(clock=10000000)
#byte
          port b = 0x06
                                              // グローバル変数の宣言
int i ;
#int ext
int_isr(){
                                              // 外部割込み関数
int eye(6) = { 0x10, 0x22, 0x32, 0xAA, 0xBA, 0xEE } ; // サイコロの目データ
                                              // ポートBにデータ出力
     port b = eye[i] ;
     delay ms(1000);
                                              // 1秒タイマの呼出し
                                              // ポートBクリア
     port b = 0x00;
}
main()
{
                                       // 割込み許可
     enable interrupts(global);
     enable interrupts(int ext);
                                        // 外部割込み許可
                                        // 割込み信号は立上りエッジ
     ext_int_edge(L_TO_H) ;
                                        // ポートBを出力に設定
     set_tris_b(0);
                                        // 割込み待ちループ
     while(1)
       for(i = 0 ; i \le 5 ; i++)
                                        // 乱数発生ループ
}
```

リスト 1.1 電子サイコロのプログラム例 (CCS コンパイラ)

図 1.10 に、実際の製作例を示します。同じような動作をする回路であるにもかかわらず、汎用ロジック IC を使用した場合(図 1.5)と比べると、IC はわずか 1 個で済んでいます。また、動作の仕方を変更する場合などは、回路はそのままで、プログラムだけを変更することで対応できる利点があります。ここで、CPU に与えたプログラムは、ハードウェア上で動作するソフトウェアであるという点に注目してください。あとで説明する CPLD や FPGA では、プログラムによってハードウェアの構築を行うという点が異なります。また、CPU を用いた場合には、CPU がプログラムを解釈しながら実行をするために、ハードウェアだけで構成したディジタル回路のようには高速動作をさせることはできません。



図 1.10 CPU (PIC マイコン)を使用した電子サイコロの製作例

#### ▶1.1.3 専用 IC を使用する方法

a

前に説明した汎用ロジック IC を使用して電子サイコロを製作する場合において、図 1.11 に示すように、6 進カウンタ回路とデコーダ回路の部分を専用 IC として製作する方法があります。発振回路は、アナログ回路ととらえて IC 化から除外しています。この例のように、ある用途のために作られた専用 IC のことを、ASIC (application specific IC:特定の用途向け IC という意味)、またはカスタム IC といいます。ここでは、簡単な電子サイコロの回路を例に挙げていますが、実際の工業製品では非常に複雑な回路を扱う場合が多くあります。



図 1.11 ASIC を使用した電子サイコロ回路の構成

ASIC を用いれば製品の製作は簡単になり、高速な動作を実現することもできます。しかし、ASIC を作るには、専門の IC メーカに依頼する必要があり、ある程度の量産(最低でも  $5000 \sim 10000$  個程度)が条件になります。総費用は非常に高くなり、できあがるまでに時間がかかるという問題も生じます。また、ASIC が本当に正しく動作するかどうかは、実際にできあがった製品で試してみるまでわかりません。仮に、テスト段階で動作を確認したとしても、それを IC 化した場合には予期せぬトラブルが発生することもあります。もしも、できあがった ASIC が正常に動作しなかった場合には、膨大な損失を被ることになってしまいます。一説では、完全に正常動作する ASIC ができあがる実際の成功率は、80%程度ともいわれています。全く使い物にならない場合は  $10\sim 20\%$ 、ASIC 外部に補正回路を接続することで何とか活かす場合も同程度あるようです。

図 1.12 に、ASIC を製作するまでの大まかな流れを示します。



図 1.12 ASIC 製作までの流れ

つぎに、ASIC の長所と短所をまとめておきます。

#### <ASIC の長所>

- ・高速動作を実現できる
- ・省スペース化を実現できる(必要最小限のサイズでICを作ることができる)
- ・量産すれば、1個あたりの価格は安くなる

#### <ASIC の短所>

- ・正常に動作しなかった場合のリスクが大きい
- できあがるまでに時間がかかる
- ・量産が条件となる
- ・後から IC 内部の回路変更ができない

#### ▶ 1.1.4 CPLD/FPGA を使用する方法

CPLD (complex programmable logic device), FPGA (field programmable gate array) とは, ユーザが内部のディジタル回路を自由に設計できる IC のことです. 本書では両者をまとめて CPLD/FPGA と表現しています. CPLD/FPGA については,後で詳しく説明しますので,ここでは、これらの IC を使った回路設計の概要をみてみましょう.

専用 IC である ASIC は、IC メーカに製作を依頼する必要がありました。しかし、ユーザ自身

0

が CPLD/FPGA とよばれる汎用 IC を専用 IC に仕立て上げる方法があります。これまでと同様に、電子サイコロを製作する場合を例に挙げて考えましょう。図 1.13 に示すように、6 進カウンタ回路とデコーダ回路の部分を CPLD/FPGA で実現します。この構成については、ASIC(図 1.11)の場合と同様です。



図 1.13 CPLD/FPGA を使用した電子サイコロ回路の構成

CPLD/FPGAは、内部にたくさんのゲート回路やそれらの配線用機能などを備えており、ユーザが目的に応じた回路に仕立て上げることができるようになっています。いろいろな規格のCPLD/FPGAが販売されていますので、ユーザは目的のディジタル回路が実現できるCPLD/FPGAを選択して購入します。そして、内部の配線などを指示するデータをCPLD/FPGAに転送すればよいのです。

図 1.14 に、CPLD/FPGA を目的のディジタル回路に仕立て上げるまでの大まかな流れを示します。



すべて自分でできる

図 1.14 CPLD/FPGA を仕立て上げるまでの流れ

図 1.14 における回路設計の作業は、従来のように汎用ロジック IC を使った回路図を書き上げるものではありません。HDL(hardware description language)とよばれるディジタル回路の構成を表現するハードウェア記述言語を使用します。これは、一見 C 言語によるプログラムなどと似ています。しかし、C 言語では CPU に与える動作手順を記述するのに対して、HDL ではCPLD/FPGA 内部を目的のディジタル回路に仕立て上げるコードを記述する点が異なります。HDLで記述されたコードは、開発用ソフトウェアによって CPLD/FPGA 内部で構成するディジタル回路を指示するデータに自動変換されます。このデータを転送(ダウンロード)すれば、CPLD/FPGA は内部の配線を変更することでユーザ専用 IC として動作するのです。

前に説明した ASIC を製作する流れ(図 1.12)の「回路設計」においても、従来は汎用ロジック IC を用いた回路設計法が用いられていましたが、現在では HDL と各種の開発用ソフトウェアを使用した設計が主流になっています。 HDL には、VHDL とよばれるものと Verilog-HDL とよばれるものが普及していますが、本書では、VHDL を中心にした説明を行います。

つぎに、ASIC と比較した CPLD/FPGA の長所と短所をまとめておきます。

#### < CPLD/FPGA の長所>

- · 1個の IC から個人レベルでも仕立て上げることができる
- · IC 内部の回路修正や変更が容易にできる
- できあがるまでの時間が短い

#### < CPLD/FPGA の短所>

- ・大量生産する場合には、ASICより1個あたりの価格が高くなる
- · ASIC ほどは高速に動作しない
- ・スペースについて ASIC ほどの最適化はできない

いくつかの短所がありますが、用途によって、特に小規模な開発で使用する場合には、それほど大きな問題とはならないものばかりでしょう。また、近年では、CPLD/FPGAの高性能化と低価格化が進み、ASICに取って代わることも多くなってきました。特に、製作までの時間が短く、回路修正が容易であるために、製品を早期に市場に投入できることは CPLD/FPGA を使う大きな利点となっています。

たとえば、図 1.15 に示すデバイスは、ザイリンクス社が販売している CPLD で、1600 個程度 のゲート回路と 72 個の FF を内蔵しています。



図 1.15 CPLD の例 (ザイリンクス社 XC9572)

リスト 1.2 は、電子サイコロ回路を実現するためのハードウェアを VHDL で記述したソースコードです。このソースコードから生成するデータを CPLD に転送すれば、CPLD は電子サイコロ回路として動作する専用 IC へと変身するのです。

```
library IEEE;
                                                      < CPLD/FPGA の特徴>
use IEEE.STD LOGIC 1164.ALL;
                                                      CPU は、ソースプログラム
use IEEE.STD LOGIC ARITH.ALL;
                                                     (C 言語) で書かれた命令をハー
use IEEE.STD LOGIC UNSIGNED.ALL;
                                                     ドウェア上で実行します。
                                                      CPLD/FPGAは、ソースコー
entity dice is
                                                     ド (HDL) で書かれたハードウェ
   Port ( LED : out std logic vector (6 downto 0);
                                                     アを構築します。
         CLK : in std logic;
         ST : in std logic);
end dice;
architecture Behavional of dice is
signal CNT: std logic vector(2 downto 0);
signal Q : std logic vector(15 downto 0);
signal CE : std logic;
begin
process (CLK)
                                         注:スイッチで生じるチャタ
begin
                                          リングの影響を避けるため
                                          に、クロック分周回路を入れ
   if CLK'event and CLK='1' then
                                          てあります.
       Q <= Q + '1';
   end if;
end process;
process (Q)
begin
   if Q = "111111111111111" then
     CE <= '1';
                                        process (CNT)
   else
                                           begin
     CE <= '0';
                                                case CNT is
   end if:
                                                      when "000" =>
end process;
                                                            LED <= "0001000";
                                                      when "001" =>
process (CE)
                                                            LED <= "0010001";
  begin
                                                      when "010" =>
                                                            LED <= "0011001";
      if (CE'event and CE='1') then
            if(ST = '1') then
                                                      when "011" =>
              if(CNT = "101") then
                                                           LED <= "1010101";
                  CNT <= "000";
                                                      when "100" =>
                                                            LED <= "1011101";
              else
                  CNT <= CNT + '1';
                                                      when others =>
            end if:
                                                           LED <= "1110111";
            end if;
                                               end case;
         end if:
                                        end process;
   end process;
                                        end Behavional;
```

リスト 1.2 電子サイコロの記述例 (VHDL)



図 1.16 CPLD を使用した電子サイコロ回路の例



図 1.17 CPLD を使用した電子サイコロの製作例

図 1.16 に CPLD を用いた電子サイコロの回路,図 1.17 に実際の製作例を示します.

CPLD/FPGA を使用すれば、それらを CPU に仕立て上げることさえ可能です。そうすれば、使いたい CPU が製造中止になることを心配する必要などはありません。

本書の目的は、VHDLを使用して CPLD/FPGA を使いこなせるようになるための基礎を身につけることです。

## CPLD/FPGA

ユーザが目的に応じて自由にカスタマイズできるデバイスは、CPLD と FPGA に大別できます. 初級レベルの VHDL を記述するならば、どちらのデバイスを使用する場合であっても記述内容 に変わりはありません。しかし、複雑で厳密な動作が要求されるディジタル回路を構成する場合 には、使用するデバイスのハードウェアを考慮した記述が要求されることもあります。ここでは、 CPLD, FPGA それぞれの特徴や差異についての基礎を学びましょう。

#### ▶ 1.2.1 CPLD

0

CPLD (complex programmable logic device) は、プログラム可能な大規模論理素子という意 味をもつデバイスの略称です. 図 1.18 に、CPLD の基本構造の例を示します.



図 1.18 CPLD の基本構造の例

CPLD は、機種によって異なる数のファンクションブロック(function block)を有しており、ファンクションブロック内には組合せ回路とマクロセル(macrocell)とよばれるフリップフロップが備わっています。図 1.18 の例では、4 個のファンクションブロック内に、おのおの 18 個のマクロセルが格納されています。スイッチマトリクス(switch matrix)は、格子状に配置された多数の配線に対してワイヤード AND 機能を用いて目的の回路を形成するように接続する働きをします。また、I/O ブロック(I/O block)は、入出力ピンを制御しています。ITAG(joint test action group)コントローラとプログラミングコントローラは、ITAG とよばれるプロトコル(通信規約)でデータ書込みを実現する機能です。

CPLD の規模を選定する場合には、マクロセルの数をひとつの目安にするとよいでしょう. CPLD は、フラッシュメモリ(EEPROM)の技術を用いて作られていますので、データを転送した後に電源を切っても、データを保持することが可能です。つまり、カスタム IC としての構成を保持できます。データは、再書込み可能で、およそ1万回以上の消去回数が保証されています。CPLD は、小/中規模な回路を実現する場合に適したデバイスです。

ザイリンクス社の CPLD を例に挙げると、XC9500、CoolRunner、CoolRunner-II などのシリーズがあります。新しいシリーズになるにしたがって、高速化と低消費電力化が進んでいます。これらの CPLD は、同じ機種でも異なるパッケージ(外形)がありますので、用途に応じた選択をすることができます。図 1.19 に、CPLD のいくつかのパッケージ例を示します。



図 1.19 CPLD のパッケージ例

また、たとえば同じ XC9572 という型番の CPLD でも、ピン数の異なる製品があります. 図 1.20 に、XC9572 の 44 ピンタイプと、84 ピンタイプの外観例を示します.

このような製品は、内部のマクロセル数などは同じなのですが、入出力用として使用できる I/O ピンの本数が異なります。

ザイリンクス社の CPLD を例に挙げると、図 1.21 のようなルールで機種番号が付けられています. したがって、機種番号に付いているマクロセル数から、そのデバイスの規模を類推することが可能です.

0



図 1.20 ピン数の異なる CPLD (どちらも XC9572)



図 1.21 CPLD の機種番号の例 (ザイリンクス社)

#### ▶ 1.2.2 FPGA

FPGA (field programmable gate array) は、現場でプログラム可能な論理素子という意味をも つデバイスの略称です。図 1.22 に、FPGA の基本構造の例を示します。



図 1.22 FPGA の基本構造の例

FPGAには、多数のCLB (configurable logic block) とよばれるブロックが敷き詰められてお り,各CLB内には数個程度のスライス(slice)とよばれる機能単位が内蔵されています。各ス ライスには、2個のD-FFとC (carry) とよばれる演算回路および、LUT (look up table) とよ ばれるプログラム可能な組合せ回路が備わっています。前に説明した CPLD ではファンクショ ンブロックという基本機能を備えていましたが、FPGA ではそれにあたる機能が CLB というこ

とになります. さらに、図 1.23 に示した FPGA では、アドレスを自由に設定して使用できる RAM, クロックを制御できる DLL (delay look loop) などの機能を搭載しています.

FPGAは、SRAMの技術を用いて作られていますので、電源を切ればデータは消失してしまい ます.つまり,カスタム IC としての構成を保持できません.したがって,電源投入のたびに, 外部の ROM からデータをダウンロード (コンフィグレーションともいいます) することが必要 となります。

しかし FPGA は、CPLD にくらべて回路規模が格段に大きいため、大規模な回路を実現する場 合に適したデバイスです. たとえば, CPLD に使用しているゲート数の総和はおよそ 750 ~ 12.000 個程度ですが、FPGA ではおよそ 5.000 ~ 8,000,000 個にまでおよびます。

ザイリンクス社の FPGA を例に挙げると、VIRTEX、SPARTAN などのシリーズがあります。 SPARTAN シリーズは、VIRTEX シリーズ中の小規模(およそ 20 万ゲート以下)のデバイスを 低価格化した量産型の製品です.

図 1.23 に FPGA. 図 1.24 にコンフィグレーション用 ROM の外観例を示します。



図 1.23 FPGA の外観例



図 1.24 コンフィグレーション用 ROM の外観例

## 1.3

### ハードウェア記述言語

CPLD/FPGA の内部構造を決めるためには、ハードウェア記述言語(HDL)を使用してソースコードを書くことが必要です。HDLには、いくつかの種類があります。ここでは、HDLの概要と HDLを用いた設計手順などについての基礎を学びましょう。

#### ▶ 1.3.1 ハードウェア記述言語の種類

0

代表的な HDL には、つぎのようなものがあります。

#### (1) VHDL

1980 年代にアメリカ国防総省の超高速 IC(VHSIC: very high speed integrated circuit)開発プロジェクトによってまとめられた HDLです。VHDLの頭文字は、このプロジェクト名の V に由来しています。1987 年、IEEE によって標準化されて以来、バージョンアップを続けている代表的な HDLです。

#### (2) Verilog-HDL

アメリカのゲートウェイ・デザイン・オートメーション社(後にケイデンス社と合併)によって開発された HDL です。当初は、論理シミュレーション用の言語として登場しました。IEEE による標準化は、VHDL よりも遅い 1995 年です。

#### (3) AHDL

CPLD/FPGA 開発メーカであるアメリカのアルテラ社が開発した HDL です。



図 1.25 VHDL と Verilog-HDL が主流

#### (4) ABEL

アメリカのデータ I/O 社の開発した HDL です.

#### (5) SFL

日本の NTT が開発した PARTHENON というハードウェア開発環境で使用するための HDL です。 SFL は structured functional language の略称です。

#### (6) systemC

OSCI (open systemC initiative) によって 2000 年に発表された設計言語です。C++ を基本としているために、すでに C++ をマスターしている技術者にとっては修得しやすいといわれています。単にハードウェアを記述するだけでなく、そのハードウェア上で動作するソフトウェアの記述もできるシステムレベル設計言語とよばれる仕様をしています。

現在の産業界では、VHDLと Verilog-HDLが HDLの主流となっています。新しく登場してきた systemC や specC などは、大いに注目されてはいますが、いまだ発展途上といっていいでしょう。また、VHDLと Verilog-HDLを比較すると、VHDLのほうが厳格な記述ルールをもっています。しかし、どちらの HDLを使用したとしても、CPLD/FPGA や開発ツールが変わるわけではなく、同様の手順で設計を行うことができます。リスト 1.3 に VHDLと Verilog-HDLの簡単な記述例を示します。

本書では、HDLの中で最も歴史のある VHDL を中心にしてハードウェアを記述する方法を解説します。



リスト 1.3 HDL の記述例

0

#### ▶ 1.3.2 ハードウェア記述言語を用いた設計手順

図 1.26 に、HDLを用いた設計の流れを示します。この流れは、VHDL、Verilog-HDLとも同 じです。



図 1.26 HDL を用いた設計の流れ

- ① 仕様設計:どのような回路を製作したいのかを明確にします。
- ② HDL コード記述: VHDL または Verilog-HDL でコードを記述します (リスト 1.3 参照). コードは、テキストファイル形式で保存します.
- ③ 論理シミュレーション:②で記述したコードを用いて、ハードウェアの動作をシミュレー ションして検証します。ここでのシミュレーションは、実際の回路で生じる遅延などを考慮しな いため、論理シミュレーションとよばれます、小規模な回路では、シミュレーションを省略する こともあります。
- ④ 論理合成: 論理的な動作を確認したコードをもとに、ディジタル回路を設計します。
- ⑤ 配置配線: ④で設計したディジタル回路を実際に使用する CPLD/FPGA 内部で構成するた めのデータを生成し、ピンの割り当てを行います(図1.27参照)。
- ⑥ 遅延シミュレーション:⑤の配置配線によって、使用する CPLD/FPGA のピン割り当てな どが決まったので、遅延を含めたシミュレーションを行います。
- 7 ダウンロードファイル作成: CPLD/FPGA へ転送できる形式のファイルを作成します.
- ⑧ ダウンロード: CPLD/FPGA とパソコンをケーブルで接続してファイルの転送を行います. ここでは、ファイルを CPLD/FPGA に転送することをダウンロードとよんでいます。
  - ⑨ 実機での動作確認: CPLD/FPGA を実機に実装して動作確認をします.



図 1.27 配置配線

これらの作業のほとんどは、パソコン上で行います。上記②、 $\widehat{4}$ 、5、 $\widehat{7}$ 、8 で使用するソフトウェアは、CPLD/FPGA メーカが提供しており、たとえば、ザイリンクス社の ISE やアルテラ社の Quartus II、MAX+PLUS II などがあります。また、 $\widehat{3}$ 、 $\widehat{6}$  で使用するシミュレーションソフトウェアは、メンターグラフィックス社の ModelSim が有名です。 ModelSim は、この分野で世界のおよそ 70 %以上のシェアを占めているといわれています。

これらのソフトウェアは、正規版以外に無償で配布されている評価版や Web (ウェブ) 版などがあります。ウェブ版は、正規版に比べて機能は限定されますが、大規模な開発以外なら十分に使用できる性能をもっています。

これまで説明したように、HDLを用いたディジタル回路の設計は、回路図を用いての設計とはだいぶ様子が異なります。HDLでは、あたかもソフトウェアを開発するかのような雰囲気で回路設計を行うのです。しかし、HDLによって回路を設計する場合でも、ディジタル回路に関するハードウェアの知識は不可欠です。たとえば、実際のディジタル回路では、伝達遅延時間が必ず生じます。回路の規模が大きくなると、この伝達遅延時間を十分に考慮した設計をしなければ正しい動作は期待できません。したがって、HDLを用いた設計においては、出来上がる回路の様子や規模をイメージしながら作業を行うことが重要になります。また、残念ながらHLDや関連する開発ツールは完全に万能なものではありません。よりよい回路を設計するためにも、ディジタル回路の知識が必要になります。



図 1.28 ディジタル回路の知識は不可欠

#### 開発環境の概要

一昔前まで、HDLでディジタル回路を設計するためには、数百万円以上の開発ツールを購入 する必要がありました.しかし,現在では,ほとんどお金をかけずに開発環境を構築することが できます。しかも、開発ツールは、高性能化し、使いやすさも格段に向上しています。ここでは、 HDL 開発で使用するツール類の概要について学びましょう.

#### ▶ 1.4.1 開発に必要なツール

図 1.29 に、HDL による回路設計で必要となるツール類を示します。



図 1.29 開発に必要なツール

開発ツールやシミュレータは、Windows や UNIX 系の OS に対応したものがありますが、本 書では、Windows パソコンを使用することを前提とします。したがって、本書の手順で実習を 行うためには、128 MB 以上のメモリ(RAM)を搭載した Windows XP または Windows 2000 が 動作するパソコンを用意してください。また、パソコンにはパラレル(プリンタ)ポートのある ことが必要です。

しかし、これらの環境が用意できなかったとしても、VHDLのソースコードは共通に使用で きますから、各自の環境に合わせた手順によって実習を行うことは可能です.

つぎに、使用する開発ツール類について順に説明していきます。

#### ▶ 1.4.2 閲発ツール

0

HDL ソースコードの記述、論理合成、配置配線、ダウンロードファイルの作成、ダウンロー ドなどの作業を統合的に行える開発ツールが、CPLD/FPGAメーカから提供されています。 Web 版は、各社のホームページからフリーでダウンロードすることができます(第7章参照)。 使用する CPLD/FPGA のメーカによって、この開発ツールを選択することになります。たとえば、アルテラ社なら Quartus II や MAX+PLUS II、ザイリンクス社なら ISE(integrated software environment)を使用します。これらの開発ツールは、VHDL だけでなく、Verilog-HDL などにも対応しています。

本書では、主として使い勝手のよいザイリンクス社の ISE WebPACK を取り上げることにしました。図 1.30 に、ISE WebPACK による開発画面の例を示します。



図 1.30 ISE WebPACK による開発画面の例

#### ▶1.4.3 シミュレータ

シミュレータは、論理シミュレーションや遅延シミュレーションを行うソフトウェアです。シミュレータとしては、メンターグラフィックス社の ModelSim が広く普及しています。アルテラ社、ザイリンクス社とも、メンターグラフィックス社と提携して、Web 版の ModelSim をフリーで配布しています(第6章参照)。

シミュレーションでは、設計した回路に任意の波形(クロック信号や入力信号など)を与えた場合の回路の動作を擬似的に表示します(図 1.26 ③ 6.参照)。図 1.31 に、ModelSim によるシミュレーション画面の例を示します。シミュレータに入力する信号を記述したファイルをテストベンチとよびます。

小規模な開発では、シミュレーションを省略して、すぐに CPLD/FPGA へのダウンロードを行い、実際に動作させることで検証を行うことも少なくありません。

本書では、ModelSim (MXEII Starter) を ISE WebPACK に組み込んで統合的な操作でシミュレーションを行う方法について説明します (第6章参照). したがって、必要なソフトウェアは



図 1.31 ModelSim によるシミュレーション画面の例

無料で用意できます。

#### ▶1.4.4 ダウンロードケーブル

a

ダウンロードケーブルは、ISE WebPACK などの開発ツールによって作成したダウンロードファイルを CPLD/FPGA に転送する際に使用します。ダウンロードには、パソコンのパラレルポート(プリンタポート)を使用する JTAG(joint test action group)方式が一般的です。このためのデータ変換回路を含むダウンロードケーブルは、各メーカから市販されています(図 1.32 参照).



図 1.32 ダウンロードケーブルの例(Insight 製)

しかし、ダウンロードケーブル内の回路はとても簡単であり、回路図などの情報も公開されていますので、安く済ませたい人は自作することが可能です。また、たとえばヒューマンデータ社 (http://www.hdl.co.jp) などからは、組み立てキットや完成品が販売されています (図 1.33 参 照)。



図 1.33 ヒューマンデータ社のダウンロードケーブル (ザイリンクス用)

また、評価ボード(評価基板)とよばれている製品は、CPLD/FPGAを使って設計した回路の動作を検討し評価するためのツールです。図 1.34 に示す評価ボードは、教育用として販売されている製品の例です。



図 1.34 教育用評価ポードの例

図 1.35 には、比較的小規模な評価ボードの外観を示します。この評価ボードには、ザイリンクス社の CPLD, XC2C256 が搭載されており、入力装置としてプッシュスイッチ、出力装置として液晶表示ディスプレイなどが用意されています。基板には、ユーザが外付け回路を製作して実験を行うスペースもあります。この評価ボードは、乾電池で動作させることも可能です。

評価ボードの中には、ダウンロードに必要な JTAG インタフェース回路を搭載したものがありますので、そのような評価ボードを使用すれば図 1.32 や図 1.33 に示したダウンロードケーブルを別途用意する必要はありません。JTAG インタフェース回路を含まない、単なるケーブルでパソコンと接続すればよいのです。



図 1.35 小規模な評価ポードの例 (Memec Japan 社)

本書では、図 1.36 に示すコストパフォーマンスのすぐれた評価ボードを基本にして実習方法 を説明します。この評価ボードは、ザイリンクス社の CPLD「CoolRunnerII シリーズの XC2C256」を採用しており、豊富な入出力装置の他、JTAG インタフェース回路も搭載していま すから、直接パソコンと接続して各種の実習を行うことができます。入手方法は、200ページで 紹介します。



図 1.36 実習用評価ボード (ソリトンウェーブ社)

#### ▶ 演習問題 1

q

- 1.1 CPU に与えるプログラムと CPLD/FPGA に与えるコードは、動作の仕方がどのように異なるのか簡単に説明しなさい。
- 1.2 つぎの文章のうち、CPLD/FPGAのもつ長所に該当するものを選びなさい。
  - ① 1個の IC から個人レベルでも仕立て上げることができる
  - ② 大量生産する場合には、ASIC より 1 個あたりの価格が安くなる
  - ③ スペースについて ASIC より最適化が可能である
  - ④ IC 内部の回路修正や変更が容易にできる
  - ⑤ 出来あがるまでの時間が短い
  - ⑥ ASIC より高速に動作する
- 1.3 つぎの文章は、CPLD と FPGA のどちらに該当するものか答えなさい。
  - ① 電源を切ってもデータを保持できる
  - ② 小・中規模な回路設計に向いている
  - ③ 中・大規模な回路設計に向いている
  - ④ ファンクションブロックという機能単位がある
  - ⑤ CLB という機能単位がある
- 1.4 最も早く IEEE によって標準化された HDL は何か.
- 1.5 論理シミュレーションと遅延シミュレーションの違いを簡単に説明しなさい。
- 1.6 テストベンチとは何か簡単に説明しなさい。
- 1.7 論理合成とはどのような作業か簡単に説明しなさい。
- 1.8 配置配線とはどのような作業か簡単に説明しなさい。
- 1.9 ダウンロードとはどのような作業か簡単に説明しなさい。
- 1.10 ダウンロードケーブルの通信規格と接続ポート (パソコン側) について簡単に説明しなさい。
- 1.11 つぎのうち、HDLを用いた実習を行う際に使用する主なツールを選びなさい。
  - ① パソコン ② ワープロソフト ③ CAD ソフト ④ シミュレータ
  - ⑤ CPLD/FPGAメーカの提供する開発ツール ⑥ イメージスキャナ
  - ⑦ ダウンロードケーブル ⑧ CPLD/FPGA 実装ボード ⑨ VHDL コンパイラ

# 第2章 設計の流れ

VHDL を用いてディジタル回路を設計する場合には、パソコンを使用した作業が不可欠になります。パソコンに VHDL のコードを入力し、論理合成や配置配線を行った後、データを実機(評価ボード)上の CPLD/FPGA にダウンロードします。

自分では理解できていると思っている事項であっても、実際に動作確認を 行ってみると、予想もしなかった思い違いやトラブルが発生することは少なく

ありません。また、実習によって新しい発見をすることも多くあります。 したがって、VHDLをマスターするためには、評価ポードを使用した実習が欠かせません。

この章では、コードの入力から評価ボードで動作確認を行うまでの流れを説明します。実際にパソコンを操作しながら、VHDLによるディジタル回路設計の流れを体験しましょう。VHDLのコードに関する詳細は、次章以降で学びます。



### ターゲットデバイス

実際に使用する CPLD/FPGA をターゲットデバイスといいます。CPLD/FPGA は、各種の製 品が販売されていますので、設計する回路に適合するターゲットデバイスを選択する必要があり ます。ここでは、ターゲットデバイス選定の考え方などについて説明します。

#### ▶2.1.1 ターゲットデバイスの選定

ターゲットデバイスを選定するためには、図2.1に示すような項目について考える必要があり ます.



図 2.1 ターゲットデバイス選定の条件

表 2.1 に, ザイリンクス社の CPLD の仕様を示します. ザイリンクス社の CPLD には, CoolRunner-II, CoolRunner XPLA3, XC9500XV, XC9500XL の 4 ファミリがあります。表 2.1 で は、各ファミリ内の型番とその仕様が示されています。たとえば、CoolRunner-IIファミリの動 作電圧は 1.8 V であり、ファミリ内の XC2C256 という型番の CPLD は、6000 個のシステムゲー ト (system gates), 256 個のマクロセル (macrocells) から構成されていることがわかります. ここで,システムゲート数とは CPLD を構成するゲートの総数であり,マクロセル数とは CPLD 内に含まれるフリップフロップの総数を示します.ターゲットデバイスの規模を選定する 場合, CPLD ではマクロセル数を目安にするとよいでしょう. ただし, 実際には, 仕様で示され ているマクロセルすべてを使用することはできませんので、何割かの余裕をもった選定を行いま しょう。

XC2C256は、各種のパッケージが製品化されていますが、入出力ピン数の最大(Max.I/O) は 184 本です、また、表 2.1 で示されているスピード (speed) は、グレード (grade) で表示さ れており、小さい数になるほど、高速動作が可能です(15ページ図1.21参照)。たとえば、 XC2C256 のグレード「5」では最大周波数 238 MHz での動作が可能です。

表 2.1 CPLD の仕様 (ザイリンクス社)

|            |              |              |                            |                          |                           | I/C<br>Featu |             |                                 | Speed                                           |                                                 | Clo           | cking                   |
|------------|--------------|--------------|----------------------------|--------------------------|---------------------------|--------------|-------------|---------------------------------|-------------------------------------------------|-------------------------------------------------|---------------|-------------------------|
|            | System Gates | Macrocells   | Product tems per Macrocell | Input Voltage Compatible | Output Voltage Compatible | Max. I/O     | I/O Banking | Min. Pin-to-Pin Logic Delay(ns) | Commercial Speed Grades<br>(fastest to slowest) | Industrial Speed Grades<br>(fastest to slowest) | Global Clocks | Product Term Clocks per |
| CoolRunner | -II Family   | <u>/ — 1</u> | .8 Vol                     | t                        |                           |              |             |                                 | VO 1.8                                          | [V],2.5[V]                                      | ,3.3          | [V]                     |
| XC2C32     | 750          | 32           | 40                         | 1.5/1.8/2.5/3.3          | 1.5/1.8/2.5/3.3           | 33           | 1           | 3.5                             | -3 -4 -6                                        | -6                                              | 3             | 17                      |
| XC2C64     | 1500         | 64           | 40                         | 1.5/1.8/2.5/3.3          | 1.5/1.8/2.5/3.3           | 64           | 1           | 4                               | -4 -5 -7                                        | -7                                              | 3             | 17                      |
| XC2C128    | 3000         | 128          | 40                         | 1.5/1.8/2.5/3.3          | 1.5/1.8/2.5/3.3           | 100          | 2           | 4.5                             | -4 -6 -7                                        | -7                                              | 3             | 17                      |
| XC2C256    | 6000         | 256          | 40                         | 1.5/1.8/2.5/3.3          | 1.5/1.8/2.5/3.3           | 184          | 2           | 5                               | -5 -6 -7                                        | -7                                              | 3             | 17                      |
| XC2C384    | 9000         | 384          | 40                         | 1.5/1.8/2.5/3.3          | 1.5/1.8/2.5/3.3           | 240          | 4           | 6                               | -6 -7 -10                                       | -10                                             | 3             | 17                      |
| XC2C512    | 12000        | 512          | 40                         | 1.5/1.8/2.5/3.3          | 1.5/1.8/2.5/3.3           | 270          | 4           | 6                               | -6 -7 -10                                       | -10                                             | 3             | 17                      |
| CoolRunner | XPLA3        | Family       | <b>/</b> —3                | .3 Volt                  |                           |              |             |                                 |                                                 | I/O 3.3[                                        | V],5          | [V]                     |
| XCR3032XL  | 750          | 32           | 48                         | 3.3/5                    | 3.3                       | 36           |             | 5                               | -5 -7 -10                                       | -7 -10                                          | 4             | 16                      |
| XCR3064XL  | 1500         | 64           | 48                         | 3.3/5                    | 3.3                       | 68           |             | 6                               | -6 -7 -10                                       | -7 -10                                          | 4             | 16                      |
| XCR3128XL  | 3000         | 128          | 48                         | 3.3/5                    | 3.3                       | 108          |             | 6                               | -6 -7 -10                                       | -7 -10                                          | 4             | 16                      |
| XCR3256XL  | 6000         | 256          | 48                         | 3.3/5                    | 3.3                       | 164          |             | 7.5                             | -7 -10 -12                                      | -10 -12                                         | 4             | 16                      |
| XCR3384XL  | 9000         | 384          | 48                         | 3.3/5                    | 3.3                       | 220          |             | 7.5                             | -7 -10 -12                                      | -10 -12                                         | 4             | 16                      |
| XCR3512XL  | 12000        | 512          | 48                         | 3.3/5                    | 3.3                       | 260          |             | 7.5                             | -7 -10 -12                                      | -10 -12                                         | 4             | 16                      |
| XC9500XV   | Family –     | - 2.5 \      | /olt                       |                          |                           |              |             |                                 |                                                 | /O 2.5[V                                        | ],3.3         | 8[V]                    |
| XC9536XV   | 800          | 36           | 90                         | 2.5/3.3                  | 1.8/2.5/3.3               | 36           | 1           | 5                               | -5 -7                                           | -7                                              | 3             | 18                      |
| XC9572XV   | 1600         | 72           | 90                         | 2.5/3.3                  | 1.8/2.5/3.3               | 72           | 1           | 5                               | -5 -7                                           | -7                                              | 3             | 18                      |
| XC95144XV  | 3200         | 144          | 90                         | 2.5/3.3                  | 1.8/2.5/3.3               | 117          | 2           | 5                               | -5 -7                                           | -7                                              | 3             | 18                      |
| XC95288XV  | 6400         | 288          | 90                         | 2.5/3.3                  | 1.8/2.5/3.3               | 192          | 4           | 6                               | -6 -7 -10                                       | -7 -10                                          | 3             | 18                      |
| XC9500XL   | Family —     | - 3.3 \      | /olt                       |                          |                           |              |             |                                 |                                                 | I/O 3.3                                         | V),5          | [V]                     |
| XC9536XL   | 800          | 36           | 90                         | 2.5/3.3/5                | 2.5/3.3                   | 36           |             | 5                               | -5 -7 -10                                       | -7 -10                                          | 3             | 18                      |
| XC9572XL   | 1600         | 72           | 90                         | 2.5/3.3/5                | 2.5/3.3                   | 72           |             | 5                               | -5 -7 -10                                       | -7 -10                                          | 3             | 18                      |
| XC95144XL  | 3200         | 144          | 90                         | 2.5/3.3/5                | 2.5/3.3                   | 117          |             | 5                               | -5 -7 -10                                       | -7 -10                                          | 3             | 18                      |
| XC95288XL  | 6400         | 288          | 90                         | 2.5/3.3/5                | 2.5/3.3                   | 192          |             | 6                               | -6 -7 -10                                       | -7 -10                                          | 3             | 18                      |

XC95--XL =9500 3.3V XC95--XV =9500 2.5V XCR-XL =CoolRunner 3.3V XC2C =CoolRunner II 1.8V

表 2.2 に、CPLD のパッケージ一覧(ザイリンクス社)を示します。同じ機種であっても PQ (plastic quad flat pack) や TQ (thin quad flat pack) など各種のパッケージ形状があります。また、同じパッケージ形状でも、入出力ピン数の違いでピンの総数が異なるデバイスがあります。たとえば、XC2C256 では、PQ、VQ、TQ、CP、FT のパッケージ形状が用意されており、それらの「入出力ピン数/ピン総数」は、それぞれ、173/208、80/100、118/144、106/132、184/256 本となっています。

表 2.2 CPLD のパッケージ一覧 (ザイリンクス社)

|        |                 |        | -      |         | /1 1.4  |         |         |           | _         |           |           |            | ,,,       |          |          |           |           |          |          |           |           |
|--------|-----------------|--------|--------|---------|---------|---------|---------|-----------|-----------|-----------|-----------|------------|-----------|----------|----------|-----------|-----------|----------|----------|-----------|-----------|
|        |                 |        | Co     | olRu    | nner    | -11     |         | С         | oolF      | Runne     | er XF     | PLA3       |           | _        | (C95     | 00X       | V         | )        | (C95     | 500X      | L         |
|        |                 | XC2C32 | XC2C64 | XC2C128 | XC2C256 | XC2C384 | XC2C512 | XCR3032XL | XCR3064XL | XCR3128XL | XCR3256XL | XCR3384XI. | XCR3512XL | XC9536XV | XC9572XV | XC95144XV | XC95288XV | XC9536XL | XC9572XL | XC95144XL | XC95288XL |
|        | Body Size       | ×      | ×      | ×       | ×       | ×       | ×       | ×         | ×         | ×         | ×         | ×          | ×         | ×        | ×        | ×         | ×         | ×        | ×        | ×         | ×         |
| PLCC   | Packages (PC)   |        |        |         |         |         |         |           |           |           |           |            |           |          |          |           |           |          |          |           |           |
| 44     | 16.5 × 16.5 mm  | 33     | 33     |         |         |         |         | 36        | 36        |           |           |            |           | 34       | 34       |           |           | 34       | 34       |           |           |
| PQFF   | Packages (PQ)   | )      |        |         |         |         |         |           |           |           |           |            |           |          |          |           |           |          |          |           |           |
| 208    | 28 × 28 mm      |        |        |         | 173     | 173     | 173     |           |           | 7         | 164       | 172        | 180       |          |          |           | 168       |          |          | 1         | 168       |
| VQFF   | Packages (VQ)   | )      |        |         |         |         |         |           |           |           | ^         |            |           |          |          |           |           |          |          |           |           |
| 44     | 12 × 12 mm      | 33     | 33     |         |         |         | F       | 36        | 36        |           |           |            |           | 34       | 34       |           |           | 34       | 34       |           |           |
| 64     | 12 × 12 mm      | 1      |        |         |         |         |         |           |           |           |           |            |           |          |          |           |           | 36       | 52       |           |           |
| 100    | 16 × 16 mm      |        | 64     | 80      | 80      |         |         |           | 68        | 84        |           |            |           |          |          |           |           |          |          |           |           |
| TOFF   | Packages (TQ)   |        |        |         |         |         |         |           |           |           |           |            |           |          |          |           |           |          |          |           |           |
| 100    | 14 × 14 mm      |        |        |         |         |         |         |           |           |           |           |            |           |          | 72       | 81        |           |          | 72       | 81        |           |
| 144    | 20 × 20 mm      |        |        | 100     | 118     | 118     |         |           |           | 108       | 120       | 118        |           |          |          | 117       | 117       |          |          | 117       | 117       |
| Chip S | Scale Packeges  | (CP)   | v      | vire-t  | ond     | chip    | -sca    | le B      | GA (      | 0.5 n     | nm b      | all s      | pacir     | ng)      |          | -         |           |          |          | -         |           |
| 56     | 6 × 6 mm        | 33     | 45     |         |         |         |         |           | 48        |           |           |            |           |          |          |           |           |          |          |           |           |
| 132    | 8 × 8 mm        |        |        | 100     | 106     |         |         |           |           |           |           |            |           |          |          |           |           |          |          |           |           |
| Chip ! | Scale Packeges  | (CS)   | — v    | vire-t  | ond     | chip    | -sca    | le B      | GA (      | 0.8 n     | nm b      | all s      | pacii     | ng)      |          |           |           |          |          | -         | -         |
| 48     | 7 × 7 mm        |        |        |         |         |         |         | 36        | 40        |           |           |            |           | 36       | 38       |           |           | 36       | 38       |           |           |
| 144    | 12 × 12 mm      |        |        |         |         |         |         |           |           | 108       |           |            |           |          |          | 117       |           |          |          | 117       |           |
| 280    | 16 × 16 mm      |        |        |         |         |         |         |           |           |           | 164       |            |           |          |          | 1         | 192       |          |          |           | 192       |
| BGA I  | Packeges (BG) - | — wi   | re-bo  | ond s   | tand    | ard E   | BGA     | (1.2      | 7 m       | m bal     | ll spa    | acing      | ))        |          |          | -         |           |          |          | -         |           |
| 256    | 27 × 27 mm      |        |        |         |         |         |         |           |           |           |           |            |           |          |          |           |           |          |          |           | 192       |
| FGA I  | Packeges (FT) - | – wir  | e-bo   | nd fir  | ne-pi   | tch t   | nin E   | GA        | (1.0      | mm        | ball:     | spac       | ing)      |          |          |           |           |          |          | 1         | -         |
| 256    | 17 × 17 mm      |        |        |         | 184     | 212     | 212     |           |           |           | 164       | 212        | 212       |          |          |           |           |          |          |           |           |
| FBGA   | Packeges (FG)   | — v    | vire-t | ond     | Fine    | line I  | BGA     | (1.0      | mn (      | ball      | spa       | cing)      |           |          |          |           |           |          | -        | 1         | 1         |
| 256    | 17 × 17 mm      |        |        |         |         |         |         | Ė         |           | Γ.        |           |            |           |          |          |           | 192       |          |          |           | 192       |
| 324    | 23 × 23 mm      |        |        |         |         | 240     | 270     |           |           |           |           | 220        | 260       |          |          |           |           |          |          | -         |           |

Automotive products are highlighted: (自動車用)
-40C to + 125C ambient temperature for CPLDs

#### Package Type:

BG = Ball Grid Array

FG = Fine-Pitch Ball Grid Array

PQ = Plastic Quad Flat Pack
HQ = High Heat Dissipation QFP

TQ = Thin Quad Flat Pack

VQ = Very Thin Quad Flat Pack

CS = Chip Scale

CG = Chip Grid Array

PC = PLCC

CP = Chip Scale

FF = Flip Chip

FT = Plastic Fine-Pitch BGA

異なる機種であっても、同じパッケージ形状で同じ総ピン数をもった CPLD では、ピン配置に互換性があります。したがって、たとえば 256 個のマクロセルを搭載した XC2C256 を使うつもりで基板を製作した後に、何かの理由でそれ以上のマクロセルを搭載した CPLD に変更する必要が生じた場合でも、基板構成を変更することなく CPLD を差し替えることが可能です。たとえば、XC2C256 の TQ144 と XC2C384 の TQ144 などが差し替え可能です。

表 2.3 にザイリンクス社 FPGA, Spartan-3 ファミリの仕様,表 2.4 にパッケージー覧を示します。FPGA では、規模の選定にシステムゲート、CLB、スライスなど(15 ページ図 1.22 参照)

|           |                           | CLB Resaurces         |                 |                          | Memory Resaurces DSP Clock Resaur |                      |                        |                                 | esaurces                |              |                               | Sp                             |         |                                                |                                              |                                              |                       |
|-----------|---------------------------|-----------------------|-----------------|--------------------------|-----------------------------------|----------------------|------------------------|---------------------------------|-------------------------|--------------|-------------------------------|--------------------------------|---------|------------------------------------------------|----------------------------------------------|----------------------------------------------|-----------------------|
|           | System gates (see note 1) | CLB Array (Row X Col) | Number of Skoas | Logic Cells (see note 2) | Max Distributed RAM (Bits)        | # 18 kbrts Block RAM | Total Block RAM (Bits) | # 18 × 18 Dedicated Multipliers | DCM Frequency (min/max) | # DCM Blocks | Digitaly Controlled Impedance | Maximum Differential I/O Pairs | Max I/O | UO Standards                                   | Commercial Speed Grades (slowest to fastest) | Industrial Speed Grades (slowest to fastest) | Config. Memory (Bits) |
| Spartan-3 | Family                    | 1 2V                  |                 |                          |                                   | 10                   | 1 2[V] 1 5             | (V) 1 8(V                       | ].2 5[V] 3 3            | V            |                               |                                | 90nm E  | Eight Layer Metal Process                      | -                                            |                                              |                       |
| XC3S50    | 50K                       | 16 - 12               | 768             | 1,728                    | 12K                               | 4                    | 72K                    | 4                               | 25.325                  | 2            | YES                           | 56                             | 124     | Single-ended                                   | 4.5                                          | -4                                           | 0.3M                  |
| XC3S200   | 200K                      | 24 - 20               | 1 920           | 4 320                    | 30K                               | 12                   | 216K                   | 12                              | 25:325                  | 4            | YES                           | 76                             | 173     | LVT7L LV0MOS3 32 5 1 8 1 5 1 2                 | -4-5                                         | -4                                           | 1 OM                  |
| XC3S400   | 400K                      | 32 - 28               | 3,584           | 8.064                    | 56K                               | 16                   | 288K                   | 16                              | 25-325                  | 4            | YES                           | 116                            | 264     | PCI3 3V 32:64-bit 33MHz,                       | -4-5                                         | -4                                           | 1.7M                  |
| XC3S1000  | 1000K                     | 48 - 40               | 7 680           | 17 280                   | 120K                              | 24                   | 432K                   | 24                              | 25 325                  | 4            | YES                           | 175                            | 391     | SSTL2 Class   & II,SSTL18Class  ,              | -4-5                                         | 4                                            | 3 2M                  |
| XC3S1500  | 1500K                     | 64 - 52               | 13 312          | 29.952                   | 208K                              | 32                   | 576K                   | 32                              | 25.325                  | 4            | YES                           | 221                            | 487     | HSTL Class   HSTL1 8 Class   & III.GTL.GTL+    | -4 -5                                        | -4                                           | 5.2M                  |
| XC3S2000  | 2000K                     | 80 > 64               | 20 480          | 46 080                   | 320K                              | 40                   | 720K                   | : 40                            | 25.325                  | 4            | YES                           | 270                            | 565     | Differentia.                                   | -4-5                                         | -4                                           | 7.7M                  |
| XC3S4000  | 4000K                     | 96 - 72               | 27,648          | 62 208                   | 432K                              | 96                   | 1,728K                 | 96                              | 25/325                  | 4            | YES                           | 312                            | 712     | LVDS2.5, BusLVDS2.5, UltraLVDS2.5, LVDS_ext2.5 | 4.5                                          | -4                                           | 11 3M                 |
| XC3S5000  | 5000K                     | 104 - 80              | 33 280          | 74 880                   | 520K                              | 104                  | 1 872K                 | 104                             | 25:325                  | 4            | YES                           | 344                            | 784     | RSDS,LDT2.5                                    | 4.5                                          | -4                                           | 13 3M                 |

表 2.3 FPGA の仕様(ザイリンクス社 Spartan-3 ファミリ)

注: speed grade は、数値が大きい程高速になります (CPLD とは逆).

表 2.4 FPGA のパッケージ 一覧(ザイリンクス社 Spartan-3 ファミリ)

|        |                 |         |          | T.        | Sp      | artan-   | 3 (1.2   | 2V)      | +        | ,        |
|--------|-----------------|---------|----------|-----------|---------|----------|----------|----------|----------|----------|
|        |                 |         | XC3S50   | XC3S200   | XC3S400 | XC3S1000 | XC3S1500 | XC3S2000 | XC3S4000 | XC3S5000 |
| Pins   | Body Size       | I/O's   | 124      | 173       | 264     | 391      | 487      | 565      | 712      | 784      |
| PQFP P | ackages (PQ)    |         |          |           |         |          | -        |          |          | -        |
| PQ208  | 30.6 × 30.6 mm  |         | 124      | 141       | 141     |          |          |          |          |          |
| VQFP P | ackages (VQ)    |         |          |           |         |          |          |          |          |          |
| 100    | 16 × 16 mm      |         | 63       | 63        |         |          |          |          |          |          |
| TQFP P | ackages (TQ)    |         |          |           |         |          |          |          |          |          |
| TQ144  | 22 × 22 mm      |         | 97       | 97        | 97      |          |          |          |          |          |
| FGA Pa | ckeges (FT) — w | re-bond | fine-p   | itch thir | BGA (   | 1.0 mn   | n ball s | oacing)  |          |          |
| FT256  | 17 × 17 mm      |         |          | 173       | 173     | 173      |          |          |          |          |
| FGA Pa | ckeges (FG) — w | ire-bon | d fine-p | itch BG   | A (1.0  | mm ba    | II spaci | ng)      | _        |          |
| FG456  | 23 × 23 mm      |         |          |           | 264     | 333      | 333      |          |          |          |
| FG676  | 27 × 27 mm      |         |          |           |         | 391      | 487      | 489      |          |          |
| FG900  | 31 × 31 mm      |         |          |           |         |          |          | 565      | 633      | 633      |
| FG1156 | 35 × 35 mm      |         |          |           |         |          | 1        |          | 712      | 784      |

の数を指標にするとよいでしょう。

FPGAは、集積度が高く大規模な回路に用いられます。表 2.1 と表 2.3 から、CPLD と FPGA のシステムゲート数を比較すると FPGA の規模の大きさがわかることでしょう。

#### ▶ 2.1.2 CPLD の例

0

ザイリンクス社 CPLD の最新ファミリは、CoolRunner-II です。この CPLD の主な特徴はつぎのとおりです。

- ① 低電圧動作 → 動作電圧 1.8 V
- ② 低消費電力  $\rightarrow$  消費電力  $10\,\mathrm{mW}$  (XC2C128 で 8 個の  $16\,\mathrm{U}$  ットカウンタを  $50\,\mathrm{MHz}$  で動作させた場合), スタンバイ時  $180\,\mu\mathrm{W}$

- ③ 複数の I/O スタンダード → 入出力ピンでは、1.5 V/1.8 V/2.5 V/3.3 V の各電圧を扱う ことが可能
  - ④ 高速動作 → 最大動作周波数 385 MHz
  - ⑤ 最大マクロセル 512 個 → ファンクションブロック 1 個あたり、マクロセル 16 個
  - ⑥ 多い I/O ピン数 → マクロセル数あたりの入出力ピン数が多い
  - (7) 4 レベルのセキュリティ → パターンの盗用を防ぐ

ここでは、CoolRunner-II ファミリに属する「XC2C256-7VQ100C」についてみてみましょう。 図 2.2 に、CPLD の外観とピン配置を示します.型番より、この CPLD は 256 個のマクロセルを もつことや, 薄型のパッケージ VQ (very thin quad flat pack) 形状をしており, ピン総数は 100 本であることなどがわかります。



図 2.2 XC2C256-7VQ100C

さらに、表 2.2 から「XC2C256-7VQ100C」を調べると、ボディサイズ (body size) は  $16 \times 16$ mm, 入出力ピン数は 80 本, 自動車用途など周囲温度 - 40 ~ + 125 ℃での動作が可能なことが わかります。また、スピードグレードは「7」であり、200 MHz を超える周波数で動作させるこ とも可能です (データシートより). 消費電力は、動作周波数によって大きく異なりますので注 意してください.たとえば,220 MHz で動作させる場合には,30 MHz の場合と比べて約 7 倍の 消費電力を必要とします.

価格は、購入店や購入個数によって異なるでしょうが、筆者が正規代理店から1個を購入した 場合は3100円でした。

#### ▶ 2.1.3 評価ボードの例

たとえば、10 進数で  $0 \sim 65535$  までのカウントを行う 16 ビットカウンタを構成する場合には、16 個のマクロセル(フリップフロップ)を使用します。このように、簡単なディジタル回路を構成して VHDL の実習を行う場合、256 個のマクロセルを備えた「XC2C256-7VQ100C」は十分な規模といえるでしょう。また、CPLD は、フラッシュメモリを搭載していますので、電源を切っても回路構成を保持できる利点があります。

以上のような観点から、本書では「XC2C256-7VQ100C」を搭載したソリトンウェーブ社の [HDL トレーナー (HDL-10)] という評価ボードを使用して実習を行うことにします。 図 2.3 に、 HDL トレーナーの外観を示しますが、詳細は第7章 195 ページを参照してください。



XC2C256-7 VQ100C

図 2.3 HDLトレーナーの外観

異なる評価ボードを使用する場合には、CPLD/FPGAの各ピンに接続されている入出力装置 (スイッチや LED) などの仕様を説明書により確認してください。

### 実装までの手順

ここでは、開発ツールを実際に操作して、VHDLで記述したコードから論理合成、配置配線 を行い, CPLD ヘダウンロードして動作させるまでの過程を実習します. 図 2.4 で実習の流れを 確認しましょう(19ページ図1.26参照)、実習環境としては、開発ツールにザイリンクス社の ISE WebPACK, 評価ボードにソリトンウェーブ社の HDL トレーナーを使用します。なお、シ ミュレーションについては、第6章で実習します。



図 2.4 実習の流れ

0

#### ▶ 2.2.1 仕樣設計

ここでの実習では、評価ボードに搭載されている7セグメント LED を0~9まで順次表示す ることを繰り返す回路を設計しましょう。ただし、リセットスイッチ (プッシュスイッチ)を押 すとリセットがかかり、表示は0から再スタートすることとします。図2.5に、この実習回路の 構成を示します。実習回路は、分周回路、10進カウンタ回路、デコーダ回路の三つに大別でき ます。



図 2.5 実習回路の構成

10 進カウンタ回路では、2 進数の 0000 ~ 1001 (10 進数の 0 ~ 9) を繰り返しカウントします。 カウンタの出力は、デコーダ回路によって 7 セグメント LED で数字を表示するデータにデコー ドされます。一方、使用する評価ボードは、4 MHz のセラロックを動作クロック源としていま す. したがって、そのまま動作させると、式 (2.1) のように  $0.25 \mu s$  の周期 T で 7 セグメント LED が変化するため速すぎて目では確認できません。

$$T = \frac{1}{f} = \frac{1}{4 \times 10^6} = 0.25 \times 10^{-6} \,\mathrm{s} = 0.25 \,\mu\mathrm{s} \tag{2.1}$$

そこで、10進カウンタ回路の動作を遅くするために分周回路を設けます。22ビットの分周回 路によって4 MHzを分周すると、その周期T'は式(2.2)のようにおよそ1秒になります。

$$T' = (0.25 \times 10^{-6}) \times 2^{22} = 1.049 \,\mathrm{s}$$
 (2.2)

つまり. 4 MHz のクロック CLK が 2<sup>22</sup> 回発生するたびに, 新しいクロック CE を 1 個作ります. そして、10 進カウンタ回路は、クロック CE によって動作させるのです。

また、リセット信号 RESET は、クロック CLK に無関係に作用する非同期リセットとします。

#### ▶ 2.2.2 VHDL コードの記述

回路の仕様設計が終わったので、開発ツールを使って VHDL のコードを記述します。ここで は、例としてザイリンクス社の ISE WebPACK6.1i を用いた手順を説明します。バージョンに よっては、手順や画面に違いがあることと思います。なお、ISE WebPACKの入手やインストー ルの方法については、第7章を参照してください。

#### ① ISE WebPACK の記動

図 2.6 に示す ISE WebPACK のアイコンをダブルクリックし、図 2.7 に示す起動画面を表示し ます.



図 2.7 起動画面

#### ② プロジェクトの準備

ISE WebPACKでは、各種のデータをプロジェクト(Project)という単位で管理します.した

がって、始めにプロジェクトの作成準備を行います、今回の実習のプロジェクト名は、「LED10」 とします. 図 2.8 に示すように、ツールバーの「File」→「New Project」を選択します.



図 2.8 「New Project」を選択

図 2.9 に示すウインドウが現れますので、「Project Name」欄に「LED10」と入力します。 「Project Location」欄にはプロジェクトを保存する場所を指定します、「Top-Level Module Type」 は、「HDL」とし、「次へ」ボタンをクリックします.



図 2.9 「New Project」 ウインドウ

引き続いて、図 2.10 に示すウインドウで、使用するターゲットデバイスや HDL の種類などを 指定します。図 2.10 のように入力したら、「次へ」ボタンをクリックします。

クリックする



図 2.10 ターゲットデバイスや HDL の種類を指定

続いて、図2.11、2.12に示すウインドウが現れますが、ここではそのまま「次へ」をクリック して先に進みます。



☑ 2.11 [Create a New Source]



図 2.13 に示すウインドウで、設定内容を確認したら「完了」ボタンをクリックします.



図 2.13 確認用ウインドウ

以上の操作で、プロジェクトの作成準備が終わりました。図 2.14 に示すように、「Module View ウインドウにプロジェクト「LED10」が追加されているはずです。



図 2.14 プロジェクトの作成準備終了

#### ③ コード入力の準備

図 2.15 に示すように、ツールバーの「Project」→ 「New Source」を選択します.



図 2.15 「New Source」を選択

図 2.16 に示すウインドウが現れますので、ウインドウ内の左欄から「VHDL Module」を選択し、「File Name」に「LED10」と入力して「次へ」ボタンをクリックします。



図 2.16 「New Source」 ウインドウ

すると、実習回路の入出力ピンを指定するウインドウが現れますので、図 2.17 に示すような設定を行いましょう。実習回路では、入力ピンがクロック CLK、リセット RESET の各 1 本、出力ピン LED が 0 から 7 までの 8 本です。「Direction」欄では、入力ピンに「in」、出力ピンに「out」を指定します。設定後に「次へ」ボタンをクリックすると、図 2.18 に示す確認ウインドウが現れますので、設定した内容を確認して「完了」ボタンをクリックします。

以上でコード入力の準備が整いました. ISE WebPACK のウインドウには、図 2.19 に示すように、「LED10.vhd」というファイル名のコード入力用ウインドウが表示されているはずです。このように、VHDL のコードを記述するファイルは、拡張子「vhd」を付ける決まりになっています。また、表示されているコード入力用ウインドウには、すでに VHDL のコードの一部が表示されています。これは、図 2.17 で指定した入出力ピンの情報などをもとに、開発ツールが自動的に必要な VHDL コードを生成したためです。この機能を活用すれば、コード入力の負担を軽減することができます。もちろん、入出力ピンなどの割り当ては、後で自由に変更することが可能です。



図 2.17 入出力ピンの設定



図 2.18 確認用ウインドウ



図 2.19 コード入力の準備終了

#### ④ コードの入力

入力する実習回路の VHDL コードをリスト 2.1 に示します. ここでは、コードの詳細につい ての理解は必要ありません。

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
-- Uncomment the following lines to use the declarations that are
-- provided for instantiating Xilinx primitive components.
--library UNISIM;
--use UNISIM. VComponents.all;
                                                            コメント文
entity LED10 is
                                                            (以降のコードでは
    Port ( CLK : in std logic;
                                                            省略します)
          RESET : in std logic;
          LED : out std_logic_vector(7 downto 0));
end LED10;
architecture Behavioral of LED10 is
                                                       ここまでは自動的に
                                                       入力されている
 begin
                                                       ここから下を新たに
 signal CNT: std logic vector(3 downto 0);
                                                       入力する
 signal Q : std_logic_vector(21 downto 0);
 signal CE : std logic;
       begin
        -- 分周回路 22ビット
        process (CLK)
        begin
           if CLK'event and CLK='1' then
              Q <= Q + '1';
          end if;
        end process;
        process (Q)
        begin
          CE <= '1';
          else
             CE <= '0';
          end if:
        end process;
        -- 10 進カウンタ回路
        process (RESET, CE)
           begin
               if (RESET = '0') then
                      CNT <= "0000";
                  elsif (CE'event and CE='1') then
                     if(CNT = "1001") then
                               CNT <= "0000";
```

```
0150
                        CNT <= CNT + '1';
               end if:
        end if:
   end process;
-- デコーダ回路
process (CNT)
    begin
          case CNT is
                    when "0000" => LED <= "10000001";
                    when "0001" => LED <= "11001111";
                    when "0010" => LED <= "10010010":
                    when "0011" => LED <= "10000110";
                    when "0100" => LED <= "11001100";
                    when "0101" => LED <= "10100100";
                    when "0110" => LED <= "10100000";
                    when "0111" => LED <= "10001101";
                    when "1000" => LED <= "10000000";
                    when "1001" => LED <= "10000100";
                    when others => LED <= "11111111";
            end case;
                                                     ここから上を新
end process;
                                                     たに入力する
end Behavioral;
```

リスト 2.1 実習回路の VHDL コード

リスト 2.1 の初めの部分は、コード自動生成機能によってすでに入力済みですから、残りの部 分を入力します.もちろん実際にキーボードから入力することもできますが,ここでは流れを体 験することが目的なので、筆者の提供するソースファイルから未入力部分をコピーするとよいで しょう (ワードパッドなどのエディタを使用して、コピーと貼り付けを行う)。リスト 2.1 を確 認しながら,未入力部分を埋めてください.または,コード入力用ウインドウの表示内容をすべ てクリアしてから、入手したソースファイルの内容すべてを貼り付けても結構です。ソースファ イルの入手方法は、まえがきのページを参照してください。



図 2.20 コード入力用ウインドウ

0



図 2.21 コードの入力を終えたウインドウ

コードの入力が終わったら、上書き保存ボタンをクリックしてコードを保存しておきましょう (図 2.21 参照).

#### ▶ 2.2.3 論理合成

論理合成などを行うメニューは、「Process View」ウインドウの「Implement Design」の中に収められています。図 2.22 に示すように、「Implement Design」の「+」記号をクリックして、「一」記号に変化させるとメニューが表示されます(図 2.23 参照)。



図 2.22 「Implement Design」の「+」記号をクリック



図 2.23 [Implement Design] のメニュー

ISE WebPACK では、論理合成のことを「Synthesize」とよびます。図 2.23 で、「Synthesize-XST の部分をダブルクリックすると論理合成が始まります。論理合成が成功すると、図 2.24 に示すように、「Synthesize-XST」の文字の前部分に緑のチェック記号が現れます。



図 2.24 論理合成の成功

もし、コードにエラー(ERROR)があり、論理合成に失敗した場合には、図 2.25 に示すよう に赤い「×」記号が現れ、下部の「Console」ウインドウにエラーメッセージが表示されます。



図 2.25 論理合成エラー

エラーメッセージの部分をダブルクリックすると、コード入力用ウインドウ内のエラー箇所に ジャンプすることができます、メッセージを参考にしてエラーを修正し、「上書き保存」を行っ てから、再び論理合成を試みます、図 2.25 では、72 行目に「end case: | が抜けていることがエ ラーの原因です,また,エラーほど重要でないが,問題点(WARNING)のある場合には,黄色 い「!」マークが表示されます(図 2.26). この場合は、メッセージを確認して、問題がないか どうか検討しましょう.



図 2.26 「WARNING」

論理合成が終了すれば、続いて配置配線に進むことができます。しかし、先へ進む前に、論理 合成によって作成された情報のいくつかをみてみましょう。

#### 1 Synthesis Report

図 2.27 に示すように, [Process View] ウインドウの「Synthesize-XST」の左側をクリックし て「- | 記号にし、下層リストを表示します. そして、リスト中の「View Synthesis Report」の 文字部分をダブルクリックすると、論理合成レポートが表示されます。



図 2.27 Synthesis Report の表示

Synthesis Report ウインドウには、論理合成の結果が表示されています。たとえば、図 2.27 の Synthesis Report には、使用した FF の数が、22 個と 4 個の計 26 個と表示されています。これは、 実習回路で分周回路に22ビットカウンタ、10進カウンタ回路に4ビットカウンタを使用したか らです.

#### (2) RTL Schematic

論理合成した回路を図として見ることができます。「Process View」ウインドウの 「Synthesize-XST」の下層リスト中の「View RTL Schematic」の文字部分をダブルクリックする と、図 2.28 に示すように、新しいウインドウが開きます。



図 2.28 RTL Schematic の表示

新たに開いたウインドウには、作成した実習回路の概要図が表示されています。この概略図の 部分をダブルクリックすると、より詳細な概要図が表示されます(図 2.29 参照)、概要図は、ウ インドウにおかれているボタンによって、拡大や縮小を行うことができます。

この RTL Schematic の表示機能は、非常に簡単な回路を論理合成した場合なら理解しやすい 回路図が表示されることがありますが、複雑な回路では表示も理解しにくくなってきます。した がって、参考程度に使用するとよいでしょう。



図 2.29 より詳細な概要図

#### ▶ 2.2.4 配置配線

論理合成が終了したので。引き続いて配置配線を行います。

#### ① ピン割り当てファイルの準備

配置配線を行うためにピンの指定を行いますが、まずピンの指定情報を記録するファイルを作 成します. 図 2.30 に示すように、メニューバーの「Project」→「New Source」を選択します。



図 2.30 「New Source」を選択

すると図 2.31 に示すウインドウが表示されますので、左の一覧から「Implementation Constraints File」をクリックし、「File Name」欄に「LED10」と入力します。「次へ」ボタンを クリックして先へ進むと,いくつかの確認用ウインドウなどが表示されますので,そのまま「次 へ | や 「完了 | ボタンをクリックして先へ進みます、すると、図 2.32 に示すように、「Module View | ウインドウに「LED10.ucf | というファイル名が表示されるはずです (この作業は、142 ページで説明するように省略することもできます).



図 2.31 File Name などを指定



図 2.32 作成した「LED10.ucf」

#### ② ピン割り当ての確認

使用する HDL トレーナーに搭載されている CPLD「XC2C256-7VQ100C」のピン割り当ては、 表 2.5 のようになっています.

| No. | 接続先     | 1/0   | No. | 接続先     | VO    | No. | 接続先     | 1/0 | No. | 接続先     | 1/0 |
|-----|---------|-------|-----|---------|-------|-----|---------|-----|-----|---------|-----|
| 1   | DEB0    | INOUT | 26  | VCC1.8V |       | 51  | VCC3.3V |     | 76  | LEDB7   | OUT |
| 2   | DEB1    | INOUT | 27  | EXT     | OUT   | 52  | LEDD6   | OUT | 77  | LEDB6   | OUT |
| 3   | DEB2    | INOUT | 28  | SPKOUT  | OUT   | 53  | LEDD5   | OUT | 78  | LEDB5   | OUT |
| 4   | DEB3    | INOUT | 29  | HEXSW3  | IN    | 54  | NC      |     | 79  | LEDB4   | OUT |
| 5   | VAUX    | IN    | 30  | HEXSW2  | IN    | 55  | LEDD4   | OUT | 80  | LEDB3   | OUT |
| 6   | DEB4    | INOUT | 31  | GND     |       | 56  | LEDD3   | OUT | 81  | LEDB2   | OUT |
| 7   | DEB5    | INOUT | 32  | HEXSW1  | IN    | 57  | VCC1.8V |     | 82  | LEDB1   | OUT |
| 8   | DEB6    | INOUT | 33  | HEXSW0  | IN    | 58  | LEDD2   | OUT | 83  | TDO     | OUT |
| 9   | DEB7    | INOUT | 34  | SW1     | IN    | 59  | NC      |     | 84  | GND     |     |
| 10  | DEB8    | INOUT | 35  | SW2     | IN    | 60  | LEDD1   | OUT | 85  | LEDB0   | OUT |
| -11 | DEB9    | INOUT | 36  | SW3     | IN    | 61  | LEDD0   | OUT | 86  | LEDA7   | OUT |
| 12  | DEB10   | INOUT | 37  | SW4     | IN    | 62  | GND     |     | 87  | LEDA6   | OUT |
| 13  | DEB11   | INOUT | 38  | VCC3.3V |       | 63  | NC      |     | 88  | VCC3.3V |     |
| 14  | DEB12   | INOUT | 39  | AIN     | INOUT | 64  | LEDC7   | OUT | 89  | LEDA5   | OUT |
| 15  | DEB13   | INOUT | 40  | BZOUT   | OUT   | 65  | NC      |     | 90  | LEDA4   | OUT |
| 16  | DEB14   | INOUT | 41  | IRXD    | IN    | 66  | NC      |     | 91  | LEDA3   | OUT |
| 17  | DEB15   | INOUT | 42  | ITXD    | OUT   | 67  | LEDC6   | OUT | 92  | LEDA2   | OUT |
| 18  | NC      |       | 43  | ICTS    | OUT   | 68  | LEDC5   | OUT | 93  | NC      |     |
| 19  | NC      |       | 44  | NC      |       | 69  | GND     |     | 94  | LEDA1   | OUT |
| 20  | VCC3.3V |       | 45  | TDI     | IN    | 70  | LEDC4   | OUT | 95  | NC      |     |
| 21  | GND     |       | 46  | NC      |       | 71  | LEDC3   | OUT | 96  | NC      |     |
| 22  | CLK1    | IN    | 47  | TMS     | iN    | 72  | LEDC2   | OUT | 97  | LEDA0   | OUT |
| 23  | CLK2    | INOUT | 48  | TCK     | IN    | 73  | LEDC1   | OUT | 98  | VCC3.3V |     |
| 24  | CLK2    | INOUT | 49  | IRTS    | IN    | 74  | LEDC0   | OUT | 99  | nRESET  | IN  |
| 25  | GND     |       | 50  | LDOD7   | OUT   | 75  | GND     |     | 100 | GND     |     |

表 2.5 CPLD のピン割り当て (HDL トレーナー)

これより、実習回路では、表 2.6 に示す入出力ピンを使用することにします。

| Ħ  | 己号    | ピン番号 | 備考           |
|----|-------|------|--------------|
| 入力 | CLK   | 22   | セラロック 4 MHz  |
| 力  | RESET | 34   | プッシュスイッチ SW1 |
|    | LED 0 | 61   |              |
|    | LED 1 | 60   |              |
|    | LED 2 | 58   |              |
| 出力 | LED 3 | 56   | 7セグメント LED   |
| カ  | LED 4 | 55   | LED 4        |
|    | LED 5 | 53   |              |
|    | LED 6 | 52   |              |
|    | LED 7 | 50   |              |

表 2.6 実習回路で使用する入出力ピン

#### ③ ピン割り当て作業

図 2.33 に示すように、「Process View」ウインドウの「User Constraints」の下層メニューを表示し、「Assign Package Pins」をダブルクリックします。



図 2.33 「Assign Package Pins」をダブルクリック

すると、図 2.34 に示すようなウインドウが開きます。



図 2.34 ピン割り当てウインドウ

左側の「Design Object List - I/O Pins」ウインドウ(図 2.35 参照)の「Loc」欄に「RESET」 → 「P34」のようにピン番号を入力していきます. ピン番号は、表 2.6 を参照してください.

| I/O Name  | I/O Direction | Loc     | Bank Function | n Blo |
|-----------|---------------|---------|---------------|-------|
| KF2F.I    | Input         | 14341 · | BANK B        |       |
| LED<7>    | Output        | P50     | BANK 14       |       |
| LED<6>    | Output        | P52     | BANK 14       |       |
| LED<5>    | Output        | P53     | BANK 13       |       |
| LED<4>    | Output        | P55     | BANK 13       |       |
| LED<3>    | Output        | P56     | BANK 13       |       |
| LED<2>    | Output        | P58     | BANK 15       |       |
| LED<1>    | Output        | P60     | BANK 15       | -     |
| LED<0>    | Output        | P61     | BANK 15       | -     |
| CLK       | Input         | P22     | BANK 5        |       |
|           |               |         |               |       |
| Group I/O |               | .oc SI  | ew I/O St     | d. 1  |

図 2.35 ピン番号の入力

ピン番号の入力を終えたら、「上書き保存」ボタンをクリックしてファイルを保存し、ピン割り当てウインドウを閉じておきます(図 2.36 参照)。



図 2.36 ファイルを保存してウインドウを閉じる

#### ④ テキストエディタによる確認

ピン割り当て情報を記録したファイル「LED10.ucf」を表示して、先ほどの設定を確認しましょう。ファイル「LED10.ucf」の表示は、「Process View」ウインドウの「Edit Constraints (Text)」をダブルクリックするか、右側ウインドウの「LED10.ucf」タグをクリックします(図 2.37 参照)。



図 2.37 「LED10.ucf」の内容を表示

入力ミスが見つかった場合には、図 2.37 の右側ウインドウ内で修正を行うことができます。 修正後は、上書き保存しておくのを忘れないようにしてください。

#### ⑤ 配置配線の実行

ピン割り当て作業が終われば、配置配線を実行することができます。図 2.38 に示すように「Module View」ウインドウ内の「led10-behavioral(LED10.vhd)」を選択し、「Process View」ウインドウ内の「Implement Design」の下層メニューにある「Fit」をダブルクリックしてください。配置配線が無事に終了すれば、緑色のチェック記号が表示されます。

配置配線後は、図 2.39 に示すように、「Process View」ウインドウ内の「Implement Design」
→ 「Fit」の下層メニューにある「Fitter Report」や「View Fitted Design (ChipViewer)」をダブ
ルクリックして各種の情報を表示することができます。



図 2.38 配置配線の実行



図 2.39 配置配線後の情報表示

#### ▶ 2.2.5 ダウンロード

続いて評価ボードにダウンロードを行うためのファイルを作成します. 図 2.40 に示すように、「Process View」ウインドウ内の「Generate Programming File」をダブルクリックします. 成功を示す緑のチェック記号が表示されたら終了です。



図 2.40 ダウンロード用ファイルを作成

評価ボードをパソコンに接続し、AC アダプタで電源を供給します。詳しくは、第7章 196 ページを参照してください。

図 2.41 に示すように、「Process View」ウインドウ内の「Generate Programming File」の下層メニューにある「Configure Device(iMPACT)」をダブルクリックします。



図 2.41 「Configure Device (iMPACT)」をダブルクリック

いくつかのウインドウが表示されますが、ここではすべてそのまま次へ進みます。そして、図 2.42 に示すウインドウが表示されたら、ダウンロードファイル「led10.jed」を選択して「開く」ボタンをクリックします。



図 2.42 ダウンロードファイルの指定

0

図 2.43 に示すように、CPLD の図を右クリックして表示されるメニューから「Program」を選 択します。



図 2.43 「Program」を選択

続いて現れるウインドウでは、そのまま「OK」ボタンをクリックします。すると、CPLDへ のダウンロードが始まります. その後, 図 2.44 に示すように, ウインドウに「Programming Succeeded と表示されればダウンロードの成功です。



図 2.44 ダウンロードの終了

#### ▶2.2.6 評価ボードによる動作確認

評価ボードの動作を確認してみましょう. 一番右側の7セグメント LED が0から9までの表 示を正しく繰り返していますか.また、一番左側のプッシュスイッチを押すとリセットがかかり、

7セグメント LED の表示が 0 から再スタートするでしょうか (図 2.45 参照). もしも, エラーの ある場合には、記述したコードやピン割り当てなどに間違いがないかどうか点検しましょう。間 違いに応じて、論理合成や配置配線、ダウンロードなどの操作を繰り返す必要があります。



図 2.45 評価ポードによる動作確認

正しい動作が確認できたら、ウインドウ右上の 🗶 ボタンをクリックして ISE WebPACK を 終了します.

#### ▶2.2.7 作成された各種ファイル

0

実習回路を評価ボード上に構成して動作させるまでの作業が終わりました。ここまでの作業で 作成されたファイルをみてみましょう. 筆者の場合は、作業フォルダ「C:\Xilinx\bin\LED10」 を指定しましたので。このフォルダの内容を表示します(図 2.46 参照)。



図 2.46 C:\\
Xilinx\text{\text{bin}\text{\text{\text{LED10}}}

数多くのファイルが作成されていますが、主要ないくつかのファイルについて説明しておきま しょう。

- ①「LED10.npl」 → 作業を統合して管理するファイルです。このファイルのアイコンをダ ブルクリックすれば、ISE WebPACK が起動し、実習回路作成の作業を再開できます。
  - ②「LED10.vhd」 → VHDLのコードが記録されたテキストファイルです.
  - ③「LED10.ucf」 → CPLD のピン割り当て情報が記録されたファイルです。
  - ④ 「led10.jed」 → 評価ボードへダウンロードするファイルです.

図 2.46 にあるすべてのファイル容量は、およそ 2 MB です. したがって、たとえば作成した データを他のパソコンへ移動する場合など、すべてのファイルをコピーしていたのではたいへん です. このような場合は、「LED10.vhd」だけをコピーして、コピー先のパソコンで再度 ISE WebPACK 6.1i による作業を行えばよいでしょう.「LED10.vhd」は、VHDLコードを記述した テキストファイルですから、ファイル容量も小さく(この場合は1.6kB)、ワードパッドなどの エディタを使用して編集することも可能です.

#### ▶ 演習問題 2

- 2.1 ターゲットデバイスの選定条件を挙げなさい。
- 2.2 つぎの条件を満たす CPLD を選定したい. 29 ページの表 2.1, 30 ページの表 2.2 を参考にして適切なザイリ ンクス社の CPLD を答えなさい。
  - ① 回路には、およそ80個のフリップフロップを使用する、
  - ② 動作電圧は、3.3 Vとする.
  - ③ 入出力ピンとして、70本を使用する。
  - ④ パッケージ形状は不問である。
  - ⑤ 自動車に搭載するため、周囲の温度条件は厳しい。
- 2.3 CPLD/FPGAの動作速度と消費電力の関係について簡単に説明しなさい。
- 2.4 実習回路 (34ページ図 2.5) において、各回路の働きを簡単に説明しなさい、
  - ① 10 進数カウンタ回路
  - ② 分周回路
  - ③ デコーダ回路
- 2.5 実習回路(34ページ図 2.5) と ISE WebPACK による入出力ピンの設定(40ページ図 2.17) を関連づけて説 明しなさい。
- 2.6 実習回路を構成した後にできるファイル「LED10.vhd」はどのようなファイルか、簡単に説明しなさい.
- 2.7 実習回路の一部を変更するため、ISE WebPACK を起動したい、どのようにすればよいか説明しなさい。
- 2.8 実習回路を動作させた場合、評価ボードの右から2番目の7セグメント LED を表示用、左から2個目の プッシュスイッチをリセット用にしたい。

表 2.7 変更後の入出力ピン

- ① ISE WebPACK を使用した場合、どの手順から作業を行えばよいか、
- ② 使用する入出力ピンについて表 2.7 を完成させなさい。
- ③ 評価ボードで変更後の動作を確認しなさい。

| Ħ  | 己号    | ビン番号 | 備考           |
|----|-------|------|--------------|
| 入力 | CLK   |      | セラロック 4 MHz  |
| カ  | RESET |      | プッシュスイッチ SW2 |
|    | LED 0 |      |              |
|    | LED 1 |      |              |
|    | LED 2 |      |              |
| 出力 | LED 3 |      | 7セグメント LED   |
| カ  | LED 4 |      | LED 3        |
|    | LED 5 |      |              |
| i  | LED 6 |      |              |
|    | LED 7 |      |              |

## 第3章組合せ回路の設計

ディジタル回路は、組合せ回路と順序回路に大別できます。組合せ回路は入力の組合せだけで出力が決まりますが、順序回路では入力の組合せに加えて回路の内部状態がどのようになっているかで出力が決まります。

この章では、VHDLを用いて組合せ回路を設計する方法を学習しましょう。 章の前半では、VHDL記述の基本的な構成や文法などについて説明します。 その後、組合せ回路として、加算回路や減算回路、デコーダやエンコーダなど の設計法を説明します。

この章で取り上げる例題は、ぜひとも実際に評価ボードへダウンロードして動作を確認してください。そして、各自で考えた回路変更などを行う実習をしてください。



## 3.1 VHDL の書き方

ここでは、VHDLの基本的な構成について説明します。VHDLのコードは、ライブラリ宣言、エンティティ宣言、アーキテクチャ宣言などから構成されています。各部の意味や記述のパターンを理解しましょう。

#### ▶ 3.1.1 基本構成

a

図 3.1 に示す AND 回路を VHDL で記述するとリスト 3.1 のようになります。リスト 3.1 に示すように、VHDL の基本的なコードは、ライブラリ宣言、エンティティ宣言、アーキテクチャ宣言の 3 プロックから構成されます。各プロックの内容をみていきましょう。



図 3.1 AND 回路

0

0

0

0 1

1 0

library IEEE; use IEEE.STD\_LOGIC\_1164.ALL; use IEEE.STD LOGIC ARITH.ALL; use IEEE.STD LOGIC UNSIGNED.ALL; ライブラリ宣言 entity samplel is Port ( A : in std logic; B : in std\_logic; F : out std logic); エンティティ言宣 end sample1; architecture Behavioral of sample1 is begin  $F \le A$  and B; アーキテクチャ宣言 end Behavioral;

リスト 3.1 VHDL コードの構成

#### ① ライブラリ (library) 宣言

ライブラリ宣言は、IEEE で標準化された各種のデータ型や演算子などを使用するために必要なライブラリとパッケージを指定します. リスト 3.2 は、リスト 3.1 のライブラリ宣言を抜き出

したものです。当面は、パターンとしてリスト 3.2 のように記述しておけばよいでしょう。図 3.2 に、ライブラリ宣言の書式を示します。 ザイリンクス社の開発ツール ISE WebPACK では、 ライブラリ宣言を自動的に記述してくれます.

library IEEE;

use IEEE.STD LOGIC 1164.ALL; use IEEE.STD LOGIC ARITH.ALL; use IEEE.STD LOGIC UNSIGNED.ALL;

リスト 3.2 ライプラリ宣言

library ライブラリ名. use ライブラリ名 パッケージ名.

図 3.2 ライプラリ宣言の書式

#### ② エンティティ (entity) 宣言

エンティティ宣言は、入力と出力の設定を行います。図 3.3 に示すように、ディジタル回路の 入出力端子を宣言するのです。



図 3.3 入出力端子の宣言

具体的には、エンティティ宣言中のポート (port) 宣言によって、入出力端子の設定を行いま す、リスト 3.3 は、リスト 3.1 のエンティティ宣言を抜き出したものです。図 3.4 に、エンティ ティ宣言の書式を示します. エンティティ名は、他のファイル名(プロジェクト名)と重複しな いようにしましょう。ポート名は、入出力端子の記号を表します。VHDLでは、大文字と小文 字の区別はありません。

entity samplel is

Port ( A : in std\_logic;

B : in std logic;

F : out std logic);

end sample1;

リスト 3.3 エンティティ宣言



図3.4 エンティティ宣言の書式

#### ・モード型

表 3.1 に示す三種類の記号で信号の方向を表します (図 3.5 参照). buffer というモード型もあ りますが、ザイリンクス社のデバイスではサポートされていません。

#### データ型

「std\_logic」は、1 ビットの信号を表します.複数ビットのデータをまとめて扱いたい場合に は、「std\_logic\_vector ( )」を使います.

表 3.1 モード型

| 3K U.I | L 35 |
|--------|------|
| 記号     | 方向   |
| in     | 入力   |
| out    | 出力   |
| inout  | 及方向  |



例)8 ビットのデータをまとめて扱う場合:「std\_logic\_vector (7 downto 0)」 データ型については、後で詳しく説明します。

#### ③ アーキテクチャ (architecture) 宣言

アーキテクチャ宣言は、ディジタル回路の機能を記述するブロックです(図3.6参照).



図 3.6 アーキテクチャ宣言は機能の記述

リスト 3.4 は、リスト 3.1 のアーキテクチャ宣言を抜き出したものです。図 3.7 に、アーキテクチャ宣言の書式を示します。

architecture Behavioral of samplel is

begin

F <= A and B;
end Behavioral;</pre>

architecture アーキテクチャ名 of エンティティ名 is ( 信号宣言部 ) begin ( 機能宣言部 ) end アーキテクチャ名 ;

リスト 3.4 アーキテクチャ宣言

図 3.7 アーキテクチャ宣言の書式

アーキテクチャ名は、他のファイル名と重複しても支障がないため、ここでは「Behavioral」を使用しました。この他、エンティティ名と関連付けしやすい名前にすることも多いようです。たとえば、エンティティ名が「sample1」ならば、アーキテクチャ名を「a\_sample1」などのようにします。このコードでは、信号宣言部を使用していませんが、これについては後で説明します。機能宣言部は、「begin」と「end」に挟まれた領域で、ここにディジタル回路の論理機能を記述します。リスト 3.4 の機能宣言部は、論理演算子「and」を用いて、図 3.8 に示すような 2 入力 AND 回路の機能を記述しています。

演算結果の代人(出力)には「<=」記号を使用します. 論理演算子には,表 3.2 に示す種類があります. 演算子には,記述の順序による優先順位がありませんので,複数の演算子を同じ文



図 3.8 機能宣言部

で使用する場合には、カッコ()を使用して優先順位を定める必要があります。

| 表 3.2 論理演算子 |  |  |  |  |
|-------------|--|--|--|--|
| 機能          |  |  |  |  |
| 論理積         |  |  |  |  |
| 論理和         |  |  |  |  |
| not 論理否定    |  |  |  |  |
| 否定論理積       |  |  |  |  |
| 否定論理和       |  |  |  |  |
| 排他的論理和      |  |  |  |  |
| 否定排他的論理和    |  |  |  |  |
|             |  |  |  |  |

各宣言部の働きが理解できたならば、リスト3.1に示したコードを評価ボードで動作させる実 習を行いましょう. HDLトレーナーを使用した場合のピン割り当ての例を表 3.3 に示します. 2 個のプッシュスイッチ SW1 と SW2 を入力 A, B に, 出力 F を 7 セグメント LED (LED4 のセグ メントg) に割り当てます.

表 3.3 リスト 3.1 のピン割り当て (HDL トレーナー)

| 記号 |   | 記号 |        | ピン番号 | 備考 |
|----|---|----|--------|------|----|
| 入  | A | 35 | SW1    |      |    |
| 力  | В | 34 | SW2    |      |    |
| 出力 | F | 61 | LED4のg |      |    |

第2章35ページで説明した手順にしたがって、コードの記述、論理合成、配置配線、ダウン ロードと操作していきます、論理合成が終了した時点で、ISE WebPACK 画面の「Process View」 ウインドウ内の「Synthesize-XST」→「View Synthesis Report」を選択すると(45 ページ図 2.27 参照) 合成された回路の情報をみることができます (図 3.9).

また,「Synthesize-XST」→「View RTL Schematic」を選択すると(46 ページ図 3.28 参照)合 成された回路図を見ることができます(図3.10)。

ダウンロードまで終了したら、プッシュスイッチを押して AND 回路として正しく動作してい るかどうかを確認しましょう。ただし、HDLトレーナーではプッシュスイッチや7セグメント LED などは負論理(ON=信号0)で動作することに注意しましょう. 図 3.11 に示すように,



図 3.9 Synthesis Report の一部



図 3.10 論理合成された回路 (RTL Schematic)



図 3.11 ド・モルガンの定理

AND 回路の入出力を負論理にすると正論理の OR 回路として動作します (ド・モルガンの定 理).

## ▶3.1.2 データ型

VHDLには、表 3.4 に示すような多くのデータ型がありますが、最もよく使用するのは、 「std\_logic」と「std\_logic\_vector」です.

「 $std\_logic$ 」では、 $0 \ge 1$  の 2 値以外に、ハイインピーダンス Z や不定値 X などの 1 ビット データを扱うことができます。そして、これらのデータを複数ビットにまとめて扱いたい場合に は、「std\_logic\_vector」を用います。具体例で確認しましょう。

| 表 3.4 | データ型 | (デー | タタイプ | ) |
|-------|------|-----|------|---|
|-------|------|-----|------|---|

| データ型                  | 説明                | データ型      | 説明               |
|-----------------------|-------------------|-----------|------------------|
| std_logic             | 0, 1, Z, X などの論理値 | boolean   | TRUE, FALSE の論理値 |
| std_logic_vector      | std_logic のベクトル型  | integer   | 整数値 (32 ピット)     |
| bit                   | 0,1 の論理値          | character | 文字 (ASCII)       |
| bit_vector bit のベクトル型 |                   | string    | character のベクトル型 |

図 3.12 に示すような、4 ビットの入力信号  $A0 \sim A3$  を受け取り、4 ビットの出力信号  $F0 \sim F3$  を出す回路を考えます。ここでは、データ型の理解が目的なので、入力信号がそのまま出力される回路とします。

この回路をデータ型「std\_logic」を使用して記述すると、リスト 3.5 のようになります。リスト 3.5 のエンティティ宣言は、リスト 3.6 のように書くことも可能ですが、リスト 3.6 で使用しているデータ型は同じ「std\_logic」です。したがって、アーキテクチャ宣言では、どちらのリストでも 1 ビット単位の代入処理を記述しなければなりません。



リスト 3.5 を論理合成した結果の回路図を図 3.13 に示します。リスト 3.6 を論理合成した結果も同じになります。



リスト 3.5 「std\_logic」を用いたコード 1



図 3.13 リスト 3.5 の回路図 (RTL Schematic)

つぎに、同じ回路をデータ型「std\_logic\_vector」によって記述しましょう。リスト 3.7 をみてください。「std\_logic\_vector」は、複数ビットの論理データをベクトルとしてまとめて扱うことができます。エンティティ宣言では、図 3.14 に示す書式でポートのビット幅と型を宣言します。

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity sample4 is
    Port ( A: in std_logic_vector(3 downto 0);
        F: out std_logic_vector(3 downto 0));
end sample4;

architecture Behavioral of sample4 is

begin
    F <= A;
end Behavioral;
```

リスト 3.7 「std\_logic-vector」を用いたコード



図 3.14 「std\_logic\_vector」の書式

そして、同じデータ型で同じビット幅をもった信号であれば、「F <= A;」のように一度にまとめて代入処理を行う記述が可能です。図 3.15 に、リスト 3.7 を論理合成した後の回路図を示します。



図 3.15 リスト 3.7 の回路図 (RTL Schematic)

## ▶ 3.1.3 signal 文

図 3.16 に示すような内部信号 X. Yをもった回路を考えましょう。



図 3.16 内部信号をもった回路

この回路は、論理演算子を組合せてつぎのように記述することができます。

 $F \le (A \text{ and } B) \text{ or } (\text{not } C)$ ;

しかし、回路によっては内部信号を考える必要が生じますので、ここではあえて内部信号X、 Yを意識したコードの記述法を説明します。

61ページで学んだエンティティ宣言は、回路から外部への入出力端子を設定するものでした。 一方、図 3.17 に示すように回路内部の信号は signal (シグナル) 文で扱います。



図 3.17 内部信号は signal 文で扱う

リスト 3.8 に、signal 文を用いて図 3.16 の回路を記述したコードを示します。VHDL の基本的 なコードは、ライブラリ宣言、エンティティ宣言、アーキテクチャ宣言の三つのブロックから構 成されていることを再確認してください。

内部信号は、signal 文で信号名とデータ型を宣言してから使用します。宣言をする場所は、 アーキテクチャ宣言の信号宣言部です(62ページ図3.7参照)。宣言を行った内部信号は、機能 宣言部で他の入出力信号と同じように使用することができます

リスト 3.9 は、リスト 3.8 のアーキテクチャ宣言を抜き出したものです。図 3.18 に、signal 文 の書式を示しますので対応させて理解してください.

なお、リスト3.8中の「--」で始まる行はコメント文です、コメント文は、論理合成などの処 理時に無視されますので、うまく使用してコードをわかりやすく記述するのに役立てるとよいで しょう.



リスト 3.8 内部信号を考えたコード



リスト 3.8 を論理合成した後の回路図を図 3.19 に示します。

ここで、大切な考え方を説明します。リスト 3.9 のアーキテクチャ宣言の機能宣言部をみてください。信号 X, Y, Fへの代入処理が合計 3 回記述されています。注意すべき点は、これらの代入処理が同時に実行されることです。このことについて、もう少し詳しく説明しましょう。

リスト 3.10 は、C 言語のあるプログラムの一部を示したものです。

リスト 3.10 C 宮語プログラムの一部

このプログラムを実行すると、初めにリスト 3.10 の 1 行目が実行され、その後 2 行目、そして 3 行目へと処理が順次進んでいきます。たとえば、2 行目の実行には、すでに終了している 1 行目の結果が必要となります。つまり、プログラムは順次(シーケンシャル: sequential)処理



図 3.19 リスト 3.8 を論理合成した回路図 (RTL Schematic)

されています。 -方、リスト 3.9 のアーキテクチャ宣言の機能宣言部では、信号 X、Y、Fへの 代入処理はすべて同時 (コンカレント: concurrent) に実行されるのです. つまり, リスト3.9 の代入処理では記述の順序は意味をもちません、このため、たとえば、リスト 3.11 とリスト 3.12 は同じ機能を表します。

以上のようなことから、リスト 3.11 やリスト 3.12 で記述した代入文をコンカレント文とよぶ こともあります、VHDLにおいて、シーケンシャルな処理を行わせたい場合には、後で学ぶ 「プロセス文」を使用します。実際に論理合成を行い、リスト 3.11 とリスト 3.12 の回路図が同じ になることを確認してください。



リスト 3.11 X,Y,F の順に記述

リスト 3.12 F.X.Y の順に記述

# 3.2 VHDL 文法の基礎

これまでに、VHDL コードの基本的な構成について学びました。VHDLのコードを記述する 文法には多くのルールがあります。ここでは、特に重要な構文である、process 文、if 文、case 文などの使用法について理解しましょう。これらの構文をマスターすると、多くのディジタル回 路を記述することができるようになります。

#### ▶ 3.2.1 process 文

0

アーキテクチャ宣言の機能宣言部で記述した複数の文は、コンカレント(同時)に並列処理されることを前項で学びました。一方、VHDLコードにおいて、一般のプログラミング言語(C 言語など)と同じように、文をシーケンシャル(一つずつ順番)に実行させたい場合があります。このようなときには、図 3.20 に示す process(プロセス)文を使用します。



図 3.20 process 文の書式

process 文では、センシティビティリスト(sensitivity list)に記述した信号に変化が起こると、シーケンシャル領域に書かれた文を上から順番に実行していきます。つまり、センシティビティリストにある信号の変化がトリガ(trigger:きっかけ)となるのです。センシティビティリストにある信号に変化がない状態では、シーケンシャル領域に書かれた文は一切実行されません。センシティビティリストには、複数の信号名を記述することができます。また、ラベル名はコメントとして使用できますが、省略することも可能です。

たとえば、入力信号 A, B, C のいずれかの信号が変化した場合に、三つの代入処理を順次実行したい場合には、図 3.21 に示すような記述を行います。図 3.21 の process 文のトリガが有効になった場合にのみ、シーケンシャル領域に書かれた文が① $\rightarrow$ ② $\rightarrow$ ③の順序で実行されます。

この他、クロックパルスをトリガにして、ある処理を順次実行したい場合などにも process 文を使用することができます。



図 3.21 process 文の例

process 文は,アーキテクチャ宣言の機能宣言部に記述します.もちろん,複数の process 文を記述することも可能です.たとえば,図 3.22 に示すようなコードを考えてみましょう.信号 S1 と S2 が同時に変化したとすると,代入文 1 と代入文 2,および二つの process 文は,同時に並列処理されます.その際,各 process 文の中の代入文 3 と代入文 4,また代入文 5 と代入文 6 はそれぞれ順次実行されることになります.

architecture Behavioral of exl is



図 3.22 実行順序の例

## ▶ 3.2.2 if 文

...

if (47) 文は,ある条件が成立するか否かで実行する処理を選択する構文です.選択された処理は,シーケンシャルに実行されます.図 3.23 に,if 文の書式とフローチャートを示します.if 文の考え方は、C などのプログラミング言語と同様です.



図 3.23 if 文

図 3.23 において、else 部は、必要なければ省略することが可能です。else 部を省略すると、ある条件が成立した場合のみ順次処理を実行し、条件が不成立の場合には何もせずに if 文を終了します(図 3.24 参照)。



図 3.24 else 部を省略した if 文

architecture Behavioral of ex2 is begin



図 3.25 if 文の記述場所

if 文は、シーケンシャルに実行される処理ですから、アーキテクチャ宣言の機能宣言部(コンカレント領域)に直接記述せずに、process 文の中に記述します(図 3.25 参照). このことは、後で学ぶ case 文も同じです。

複数の条件を順番に判定することで、実行する順次処理を選択したい場合には、elsif (x) (エルスイフ) 文を使用します。図 3.26 に、elsif 文の書式とフローチャートを示します。elsif 文では、elsif のスペルに注意しましょう (elseif ではない)。



図 3.26 elsif 文

if 文や elsif 文の条件は、表 3.5 に示す関係演算子を用いて記述します。

| 表 3.5 舆除演算于 |         |  |  |  |  |  |
|-------------|---------|--|--|--|--|--|
| 演算子         | 機能      |  |  |  |  |  |
| =           | 等しい     |  |  |  |  |  |
| /=          | 等しくない   |  |  |  |  |  |
| <           | 右辺より小さい |  |  |  |  |  |
| >           | 右辺より大きい |  |  |  |  |  |
| <=          | 右辺以下    |  |  |  |  |  |
| >=          | 右辺以上    |  |  |  |  |  |
|             |         |  |  |  |  |  |

**第35** 関係溶管子

つぎに、process 文と if 文を使う例題をみてみましょう。図 3.27 に示す AND/OR セレクタ回路を考えます。選択信号 S が 0 のときは出力 F に入力 A と B の AND、S が 0 のときは出力 F に入力 A と B の OR が出力される回路です。VHDL のコードでは、選択信号 S の値を if 文で判定して AND か OR の動作を選択します。また、process 文のセンシティビティリストには、入力 A, B および、選択信号 S を記述します。リスト 3.13 に、if 文を用いたコードの記述例を示します。



図 3.27 AND/OR セレクタ回路



リスト 3.13 if 文を使った AND/OR セレクタ回路

**表 3.6** ピン割り当て (HDLトレーナー)

| 記号 |   | ピン番号 | 備考     |
|----|---|------|--------|
|    | A | 35   | SW2    |
| 入力 | В | 36   | SW3    |
|    | S | 34   | SW1    |
| 出力 | F | 61   | LED4のg |

process 文のセンシティビティリストには、すべての入力信号 A,B,S を記述することに注意してください。

HDLトレーナーを使用して、表 3.6 のようなピン割り当てを行い実習してみましょう。HDLトレーナーのプッシュスイッチと 7 セグメント LED は、負論理動作をしますので、図 3.27 の真理値表を、入力  $0 \rightarrow$  スイッチ ON (押す)、入力  $1 \rightarrow$  スイッチ OFF (離す) および、出力  $0 \rightarrow$  LED 点灯、出力  $1 \rightarrow$  LED 消灯と読み替えて実習してください。

## ▶ 3.2.3 case 文

9

case (ケイス) 文は、信号の値によって実行する処理を選択する構文です。図 3.28 に、case 文の書式とフローチャートを示します。



図 3.28 case 文

信号が、「信号の値1」ならば処理1、「信号の値2」ならば処理2を実行します、信号の値が、 記述したどれにも該当しない場合には、when others 以下の処理 n を実行して case 文を終了し ます.

case 文も if 文と同様 process 文の中に記述します. しかし, if 文では処理がシーケンシャルに 実行されましたが、case 文ではすべての when 以下の判定がコンカレントに並列実行されます。 したがって、when 以下に記述する「信号の値」には、同じ値があってはいけません、また、 when others 句を用いて、式がとりうるすべての値を記述することが必要です。

リスト 3.14 は、図 3.27 に示した AND/OR セレクタ回路を case 文で記述したコードです。こ のコードでは、選択信号のとりうる値(0と1)をすべて記述してありますが、この場合でも

```
library IEEE;
                    use IEEE.STD LOGIC 1164.ALL;
                    use IEEE.STD_LOGIC_ARITH.ALL;
                    use IEEE.STD LOGIC UNSIGNED.ALL;
                    entity sample7 is
                       Port ( A,B,S : in std_logic;
                              F : out std logic);
                    end sample7;
                    architecture Behavioral of sample7 is
                                                             センシティピティリスト
                    begin
                    process (A, B, S)
                                                                    S='0'の場合
case 文は process 文の
                    begin
                                                                    の代入処理
中に書く
                            case (S) is
                                    when '0' => F <= A and B;
                                    when '1' => F <= A or B;
                                                                    S='1'の場合
                                                                    の代入処理
                                   when others => null ; ,
                            end case;
                    end process;
                                                                  when others 句は
                                                                  省略できない
                    end Behavioral;
```

リスト 3.14 case 文を使った AND/OR セレクタ回路

when others 句は省略できないことに注意してください。 ザイリンクス社では、このような場合 の when others 句に [null] と記述することを推奨しています。

図 3.29 に、when 句の記述例とその動作を示します。代入処理を表す記号「<=」は、関係演算子の「右辺以下」(73ページ表 3.5)と同じ記号ですが、使用する場所でどちらの機能を示しているか判断してください。



図 3.29 when 句の記述例と動作

また、リスト 3.13 やリスト 3.14 の式(選択信号 S)のデータ型は「 $std_logic$ 」で指定していたので信号の値にはシングルコーテーション「'」を使用しました。もし、データ型として複数ビットをまとめて扱う「 $std_logic_vector$ 」を指定した式の場合には、ダブルコーテーション「"」を使用して信号の値を記述します。

## ▶3.2.4 動作記述と構造記述

a

図 3.30 は、前に扱った AND/OR セレクタ回路(図 3.27)と同じものです。

この回路は、真理値表から求めた論理式をカルノー図などによって簡単化することで、図 3.31 のようなディジタル回路で構成できることがわかります。

図 3.30 と図 3.31 は同じ動作をする回路ですが、図 3.30 ではブロック図と真理値表を用いて動作を表しているのに対して、図 3.31 では具体的な回路の構造を表しています。VHDLでコードを記述する際にも、同様に二種類の書き方が考えられます。図 3.30 のように回路の動作を考えた書き方を動作記述、図 3.31 のように回路の構造を考えた書き方を構造記述といいます。リス



図 3.30 AND/OR セレクタ回路 (動作図)



図 3.31 AND/OR セレクタ回路(構造図)

ト 3.15 に case 文を使用した動作記述(リスト 3.14 と同じ),リスト 3.16 に signal 文を使用した 構造記述によるコードを示します.動作記述を行えることは,VHDL を用いた設計の大きな長 所の一つです.

```
library IEEE;
                                             library IEEE;
use IEEE.STD LOGIC 1164.ALL;
                                             use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
                                             use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
                                             use IEEE.STD LOGIC UNSIGNED.ALL;
entity sample7 is
                                             entity sample8 is
    Port ( A,B,S : in std_logic;
                                                 Port ( A,B,S : in std_logic;
                F : out std logic);
                                                                 F : out std logic);
end sample7;
                                             end sample8;
architecture Behavioral of sample7 is
                                             architecture Behavioral of sample8 is
begin
                                             signal X, Y, Z : std logic;
process (A, B, S)
begin
                                             begin
    case (S) is
            when '0' \Rightarrow F \iff A and B;
                                             X \le A and B;
            when '1' => F <= A or B;
                                                      Y \le A and S;
            when others => null;
                                                      Z \le B and S;
   end case;
                                                      F \le X \text{ or } Y \text{ or } Z:
end process;
                                             end Behavioral;
end Behavioral:
                                                      リスト 3.16 構造記述
```

リスト 3.15 動作記述

## ▶3.2.5 VHDL の演算子と予約語

表 3.7 に、VHDL で使用できる演算子とその優先順位の一覧を示します。優先順位の数字は、1 が最も優先順位が高く、数字が大きくなっていくほど優先順位が低くなってきます。優先順位の変更には、カッコ「( )」を使用します。

表 3.8 に、VHDL の予約語一覧を示します。ここに示した予約語は、入力や出力の信号名などに使用することはできません。

表 3.7 VHDL の演算子

| 種類     | 演算子  | 機能         | 優先順位 |
|--------|------|------------|------|
| 論理 not |      | 論理否定       | 1    |
|        | and  | 論理積        |      |
|        | or   | 論理和        |      |
|        | nand | 否定論理積      | 6    |
|        | nor  | 否定論理和      | 0    |
|        | xor  | 排他的論理和     |      |
|        | xnor | 否定排他的論理和   |      |
| 算術     | abs  | 絶対値        | 1    |
|        | **   | べき乗        | 1    |
|        | +    | 正の符号       |      |
|        | _    | 負の記号       | 3    |
|        | +    | 加鲜         |      |
|        | -    | 減算         | 4    |
|        | *    | 乗算         |      |
|        | /    | 除算         |      |
|        | mod  | 被除数と同符号の余り | 2    |
|        | rem  | 除数と同符号の余り  |      |
| 関係     | =    | 等しい        |      |
|        | /=   | 等しくない      |      |
|        | <    | 右辺より小さい    | 5    |
|        | >    | 右辺より大きい    | 5    |
|        | <=   | 右辺以下       |      |
|        | >=   | 右辺以上       |      |
| 連接     | &    | ピットの結合     | 4    |

\*優先順位は1が最も高い

#### 表 3.8 VHDL の予約語

abs access after alias all and architecture array assert attribute begin block body buffer bus case component con guration constant disconnect downto else elsif end entity exit file for function generate generic group guarded if impure in inertial inout is label library linkage literal loop map mod nand new next nor not null of on open or others out package port postponed procedural procedure process portected pure range record reference register reject rem report return rol ror select severity signal shared sla sll sra srl subtype then to transport type unaffected units until use variable wait when while with xnor xor

## 3.3

## 各種の組合せ回路

これまで、組合せ回路を記述するために必要な基礎知識について学んできました。ここでは、加算器や減算器、デコーダやエンコーダなど簡単な各種の組合せ回路を設計してみましょう。例 題形式で問題を示しますので、まずは自分で考えてみてください。

また、できるだけ実際の開発ツールや評価ボードを用いた実習を行いながら学習を進めてください。ただし、HDLトレーナーのプッシュスイッチや 7 セグメント LED などは、負論理動作をしますので、各真理値表の、入力  $0 \rightarrow$  スイッチ ON(押す)、入力  $1 \rightarrow$  スイッチ OFF(離す)および、出力  $0 \rightarrow$  LED 点灯、出力  $1 \rightarrow$  LED 消灯などと読み替えて実習を行ってください。

### ▶3.3.1 加算器と減算器

9

半加算器 (HA: half adder) は、1 ビットどうしの加算を行う回路です。図 3.32 に半加算器の真理値表と回路を示します。

| 真牙   | 00 / | 4.   | 4    |
|------|------|------|------|
| D 15 | 99.4 | 1631 | 2000 |
| 200  | 45   | 10.7 | 15   |

| A | В | S | C |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 1 | 0 |
| 1 | 1 | 0 | 1 |



図 3.32 半加算器

#### 例題 3-1

半加算器をVHDLで記述しなさい。ただし、構造記述とすること。

#### 解答例

論理演算子を使用して記述したコードをリスト 3.17 に示します。表 3.9 に示すピン割り当てを行い実習で動作 を確認してみましょう。

表 3.9 例題 3-1 のピン割り当て

| 53 | 号 | ピン番号 | 備考       |
|----|---|------|----------|
| 入  | A | 34   | SW1      |
| カ  | В | 35   | SW2      |
| 出力 | S | 74   | LED3 Ø g |
| 力  | С | 61   | LED4のg   |

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei3 1 is
    Port ( A : in std logic;
           B : in std logic;
           S : out std logic;
           C : out std logic);
end rei3 1;
architecture Behavioral of rei3_1 is
begin
           S <= A xor B :
           C \le A and B;
```

end Behavioral;

リスト 3.17 半加算器のコード (構造記述)

#### 例題 3-2

半加算器を VHDL で記述しなさい. ただし, 算術演算子「+」を用いた動作記述とすること.

#### 解答例

論理演算子を使用して記述したコードをリスト 3.18 に示します。



入力A+Bを算術的に加算した結果は、2ビットになります。その下位ビットが和S、上位ビットが桁上がりCです. リスト 3.18 ①では、2 ビットの内部信号 ADD を宣言しています. VHDL では、代入される側とする側の ビット幅は同じでなければなりません、したがって、ADDと同じビット幅になるように、連接演算子&を用いて、

入力AとBを2ビットに変換してから加算しています(リスト3.18②)、その後、ADDの下位ビットとADD(0)上位ビットADD(1)をそれぞれ出力SとCに代入しています(リスト3.18③)。

これまでは、ライブラリ宣言でつぎの三つのパッケージを宣言していました。

STD LOGIC\_1164.ALL ・・・・・データ型を使用するためなどに必要

STD LOGIC ARITHALL ・・・・・符号なし、符号あり演算の両方をするために必要

STD LOGIC\_UNSIGNED.ALL ・・・・符号なし演算をするために必要

ここでは、符号なし演算に限定した処理を行いたいので、パッケージ STD\_LOGIC\_ARITH.ALL は、コメント文にしておきます(リスト 3.18 ④)。

表 3.9 に示すピン割り当てを行い実習で動作を確認してみましょう。また、「View RTL Schematic」によって論理合成した回路を表示すると、図 3.33 のようになっており、図 3.32 と等価であることが確認できるはずです。



図 3.33 リスト 3.18 の論理合成結果 (RTL Schematic)

半加算器は、上位ビットに桁上がり信号 C を渡すことはできますが、下位ビットからの桁上がり信号を受け取ることはできません。つまり、複数ビットどうしの演算には、使用することができない半人前の加算器です。これに対して、全加算器 (FA: full adder) は、下位ビットからの桁上がり信号  $C_c$  を受け取ることのできる一人前の加算回路です。図 3.34 に、全加算器の真理値表とブロック図を示します。

| 真理 | 里值 | 表     |   |    |                       |
|----|----|-------|---|----|-----------------------|
| A  | В  | $C_L$ | S | Co |                       |
| 0  | 0  | 0     | 0 | 0  | 7                     |
| 0  | 0  | 1     | 1 | 0  | 入力 出力                 |
| 0  | 1  | 0     | 1 | 0  | $A \longrightarrow S$ |
| 0  | 1  | 1     | 0 | 1  | <i>B</i>              |
| 1  | 0  | 0     | 1 | 0  | $C_i$ $C_o$           |
| 1  | 0  | 1     | 0 | -1 |                       |
| 1  | 1  | 0     | 0 | -1 |                       |
| 1  | 1  | 1     | 1 | 1  | プロック図                 |

図 3.34 全加算器

## 例題 3-3

全加算器をVHDLで記述しなさい。ただし、算術演算子「+」を用いた動作記述とすること。

#### 州省伊

リスト 3.19 に全加算器のコードを示します。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
--use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei3 3 is
  Port ( A : in std_logic;
         B : in std_logic;
         C I : in std logic;
         S : out std logic;
         C 0 : out std logic);
end rei3 3;
architecture Behavioral of rei3 3 is
          signal ADD : std_logic_vector(1 downto 0) ;
begin
          ADD <= ('0' & A) + ('0' & B) + ('0' & C I);
          S \leq ADD(0);
         C_O <= ADD(1) ;
end Behavioral;
```

リスト 3.19 全加算器のコード (動作記述)

半加算器と比べると、入力信号 C、が増えていますが、基本的な記述は同じです。表 3.10 に示すビン割り当てを行い実習で動作を確認してみましょう。

記号 ピン番号 備考 ASW1 B35 SW2  $C_6$ 36 SW3 S 出力 74 LED3 Og LED4のg

表 3.10 例題 3-3 のピン割り当て

全加算器は、半加算器2個を使用して図3.35に示すように構成することもできます。



図 3.35 半加算器を用いた全加算器の構成

## 例题3 。

半加算器2個を用いた全加算器をVHDLで記述しなさい。ただし、構造記述とすること、

#### 联各侧

この全加算器の回路は、図3.36に示すようになります。



図 3.36 半加算器を用いた全加算器の回路

前段の半加算器の出力を内部信号  $S0 \ge C0$ , 後段の半加算器の出力を内部信号  $C1 \ge 1$  として記述したコードをリスト 3.20 に示します。表 3.10 に示すピン割り当てを行い実習で動作を確認してみましょう。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC_UNSIGNED.ALL;
entity rei3_4 is
    Port ( A : in std logic;
           B : in std logic;
           C I : in std logic;
           S : out std logic;
           C O : out std logic);
end rei3 4;
architecture Behavioral of rei3 4 is
       signal S0,C0,C1: std_logic;
begin
      SO <= A xor B;
      CO \le A and B;
      C1 <= C_I and S0 ;
       S <= C_I xor S0 ;
       C O <= C1 or C0;
end Behavioral;
```

リスト 3.20 全加算器のコード (構造記述)

半減算器 (HS: half subtracter) は、1 ビットどうしの減算を行う回路です。図 3.37 に半減算器の真理値表と回路を示します。

| 35.3E国国35 |   |   |    |  |  |  |  |
|-----------|---|---|----|--|--|--|--|
| A         | B | D | Bo |  |  |  |  |
| 0         | 0 | 0 | 0  |  |  |  |  |
| 0         | 1 | 1 | 1  |  |  |  |  |
| 1         | 0 | 1 | 0  |  |  |  |  |
| -1        | 1 | 0 | 0  |  |  |  |  |

古田佔主



図 3.37 半減算器

## 例題当る

半減算器を VHDL で記述しなさい。ただし、構造記述とすること、

#### 斯洛彻

リスト 3.21 に半減算器のコードを示します。表 3.10 に示すピン割り当てを行い実習で動作を確認してみましょう。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei3 5 is
    Port ( A : in std logic;
           B : in std logic;
           D : out std_logic;
           B_O : out std_logic);
end rei3 5;
architecture Behavioral of rei3 5 is
           signal X, Y:std logic;
begin
           X \le A and (not B);
           Y \le B and (not A);
           D \le X \text{ or } Y;
           B O <= Y ;
end Behavioral;
```

リスト 3.21 半減算器のコード (構造記述)

表 3.11 例題 3-5 のピン割り当て

| āč | 一号    | ピン番号 | 備考       |  |  |
|----|-------|------|----------|--|--|
| 人  | A     | 34   | SW1      |  |  |
| 力  | В     | 35   | SW2      |  |  |
| 出力 | D     | 74   | LED3 の g |  |  |
| 力  | $B_o$ | 61   | LED4 の g |  |  |

半減算器は、上位ビットに桁借り信号Bを渡すことはできますが、下位ビットからの桁借り信号を受け取ることはできません。これに対して、全減算器 (FS: full subtracter) は、下位ビットからの桁借り信号B,を受け取ることのできる減算回路です。図 3.38 に、全減算器の真理値表とブロック図を示します。

真理值表

| $ABB_i$ | Q.Bo |
|---------|------|
| 0 0 0   | 0 0  |
| 0 0 1   | 1 1  |
| 0 1 0   | 1 1  |
| 0 1 1   | 0 1  |
| 1 0 0   | 1 0  |
| 1 0 1   | 0 0  |
| 1 1 0   | 0 0  |
| 1 1 1   | 1 1  |
| 1 0 1   | 0 0  |



図 3.38 全減算器

## 例照注 6

全減算器をVHDLで記述しなさい。ただし、算術演算子「一」を用いた動作記述とすること。

#### 解吞倒

リスト 3.22 に全滅算器のコードを示します、2 ビットの内部信号 SUB を宣言しています(リスト 3.22 ①). SUB と同じビット幅になるように、連接演算子&を用いて、人力 A、B、 $B\_I$  を 2 ビットに変換してから減算しています(リスト 3.22 ②). その後、SUB の下位ビット SUB (0) と上位ビット SUB (1) をそれぞれ出力 D と  $B\_O$  に代入しています(リスト 3.22 ③). また、パッケージ IEEE.STD\_LOGIC\_ARITH.ALL は、コメント文を用いて無効にしておきましょう(リスト 3.22 ④).



771 0.22 ±777 000 1 (2011 0000

表 3.12 に示すピン割り当てを行い実習で動作を確認してみましょう。

記号 ピン番号 備考 34 SW1 SW2 B35 SW3 В. 36 D 74 LED3 Og 出 力  $B_{\alpha}$ 61 LED4 Og

表 3.12 例題 3-6 のピン割り当て

## ▶3.3.2 エンコーダとデコーダ

エンコーダ (encoder) は、人が見て意味のわかるデータをディジタル回路用のデータに変換する働きをする回路で、符号器ともよばれます。たとえば、10 進数のデータを 2 進数に変換するエンコーダなどがあります。図 3.39 に、10 進-2 進エンコーダの例を示します。このエンコー

Q

ダは、10 進数の $0 \sim 3$  までに対応させた 4 本の入力ピン $A_3$ 、 $A_2$ 、 $A_1$ 、 $A_0$  のうち、信号 1 を入力 したピンを有効とします。そして、入力した 10 進数を 2 進数に変換して、出力ピン  $F_1$ 、 $F_0$  から 2ビットで出力します。

| 真理値表                                                                                                                                                                                          | 0 1 0 0 ← 入力例 (2)10                                                     |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|
| A3     A2     A1     A0     F1     F0       0     0     0     1     0     0       0     0     1     0     0     1       0     1     0     0     1     0       0     1     0     0     1     0 | (3) <sub>10</sub> (2) <sub>10</sub> (1) <sub>10</sub> (0) <sub>10</sub> |
| 1 0 0 0 1 1                                                                                                                                                                                   | 1 0 ← 出力例 (10)2 動作                                                      |

図 3.39 10 進-2 進エンコーダの例

### 例題 3-

図 3.39 に示したエンコーダを VHDL で記述しなさい. ただし,動作記述とすること.

#### 解答别

リスト 3.23 にエンコーダのコードを示します。入力と出力のデータ型には、ベクトル型 std\_logic\_vector を使用 しました。そして、case 文を用いて入力データを判定し、出力データ型を決めています (74ページ参照)。この 例題では、4ビット入力(16通りのデータ)のうちの4通りのデータのみを使用していますので、未使用入力に ついては when others 句で Fに "11" を代入しました。また,case 文は process 文の中に記述することに注意して ください、process 文のセンシティピティリストには、入力信号 A を記述します。



リスト 3.23 エンコーダのコード (動作記述)

表 3.13 に示すピン割り当てを行い実習で動作を確認してみましょう.

| 記号    |      | ピン番号 | 備考       |  |
|-------|------|------|----------|--|
|       | A(0) | 37   | SW4      |  |
| The I | A(1) | 36   | SW3      |  |
|       | A(2) | 35   | SW2      |  |
|       | A(3) | 34   | SW1      |  |
| 出力    | F(0) | 61   | LED4 の g |  |
| カー    | F(1) | 74   | LED3 の g |  |

表 3.13 例題 3-7 のピン割り当て

デコーダ (decoder) は、ディジタル回路用のデータを人が見て意味のわかるデータに変換する働きをする回路で、復号器ともよばれます。つまり、エンコーダとは逆の働きをする回路であると考えることができます。たとえば、2 進数のデータを 10 進数に変換するデコーダなどがあります。図 3.40 に、2 進-10 進デコーダの例を示します。このデコーダは 2 ビットの 2 進数入力  $A_1$ 、 $A_0$  を 10 進数に変換します。変換結果は、10 進数の  $3 \sim 0$  までに対応させた 4 本の出力ピン  $F_3$ 、 $F_2$ 、 $F_1$ 、 $F_0$  から出力します。

| 真理值表 | F <sub>2</sub> | Fa | $F_1$ | Fo |
|------|----------------|----|-------|----|
| 0 0  | 0              | 0  | 0     | 1  |
| 0 1  | 0              | 0  | 1     | 0  |
| 1 0  | 0              | 1  | 0     | 0  |
| 1 1  | 1              | 0  | 0     | 0  |

begin



図 3.40 2 進-10 進デコーダの例

## 例類3-8

図 3.40 に示したデコーダを VHDL で記述しなさい。ただし、動作記述とすること。

#### 解答例

リスト 3.24 にデコーダのコードを示します。動作の流れとしては、リスト 3.23 で学んだエンコーダとほとんど同じです。

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity rei3_8 is
   Port ( A : in std_logic_vector(1 downto 0);
        F : out std_logic_vector(3 downto 0));
end rei3_8;

architecture Behavioral of rei3 8 is
```



end Behavioral;

リスト 3.24 デコーダのコード (動作記述)

表 3.14 に示すピン割り当てを行い実習で動作を確認してみましょう。

表 3.14 例題 3-8 のピン割り当て

|    | 記号      | ピン番号 | 備考       |
|----|---------|------|----------|
| 入力 | A(1) 34 |      | SW1      |
| 力  | A(0)    | 35   | SW2      |
|    | F(3)    | 97   | LED1のg   |
| 出力 | F(2)    | 85   | LED2 の g |
| 力  | F(1)    | 74   | LED3のg   |
|    | F(0)    | 61   | LED4のg   |

表 3.15 ロータリスイッチの動作

| SC 0.10 |       | 7 7 7 | 1 / / ! | マノラルコト |
|---------|-------|-------|---------|--------|
| 位置      |       | 出     | カ       |        |
| 九  風    | $H_3$ | $H_2$ | H       | $H_0$  |
| 0       | 0     | 0     | 0       | 0      |
| 1       | 0     | 0     | 0       | 1      |
| 2       | 0     | 0     | 1       | 0      |
| 3       | 0     | 0     | 1       | 1      |
| 4       | 0     | 1     | 0       | 0      |
| 5       | 0     | 1     | 0       | 1      |
| 6       | 0     | 1     | 1       | 0      |
| 7       | 0     | 1     | 1       | 1      |
| 8       | 1     | 0     | 0       | 0      |
| 9       | 1     | 0     | 0       | 1      |
| A       | 1     | 0     | 1       | 0      |
| В       | 1     | 0     | 1       | 1      |
| C       | 1     | 1     | 0       | 0      |
| D       | 1     | 1     | 0       | 1      |
| E       | 1     | 1     | 1       | 0      |
| F       | 1     | 1     | 1       | 1      |

表 3.16 7セグメント LED の表示 (0 で点灯)

|   | 入力 |   |   |   |   |   |    | 表示 |
|---|----|---|---|---|---|---|----|----|
| a | b  | С | d | e | f | g | dp | 政小 |
| 0 | 0  | 0 | 0 | 0 | 0 | 1 | 1  | 0  |
| 1 | 0  | 0 | 1 | 1 | 1 | 1 | 1  | 1  |
| 0 | 0  | 1 | 0 | 0 | 1 | 0 | 1  | 2  |
| 0 | 0  | 0 | 0 | 1 | 1 | 0 | 1  | 3  |
| 1 | 0  | 0 | 1 | 1 | 0 | 0 | 1  | 4  |
| 0 | 1  | 0 | 0 | 1 | 0 | 0 | 1  | 5  |
| 0 | 1  | 0 | 0 | 0 | 0 | 0 | 1  | 5  |
| 0 | 0  | 0 | 1 | 1 | 0 | 1 | 1  | 7  |
| 0 | 0  | 0 | 0 | 0 | 0 | 0 | 1  | 8  |
| 0 | 0  | 0 | 0 | 1 | 0 | 0 | 1  | 9  |
| 0 | 0  | 0 | 1 | 0 | 0 | 0 | 1  | R  |
| 1 | 1  | 0 | 0 | 0 | 0 | 0 | 1  | 6  |
| 0 | 1  | 1 | 0 | 0 | 0 | 1 | 1  | E  |
| 1 | 0  | 0 | 0 | 0 | 1 | 0 | 1  | d  |
| 0 | 1  | 1 | 0 | 0 | 0 | 0 | 1  | E  |
| 0 | 1  | 1 | 1 | 0 | 0 | 0 | 1  | F  |

つぎに、デコーダの応用回路として7セグメント LED に数字を表示させてみましょう。HDLトレーナーには、16 進数のロータリスイッチが搭載されています。このスイッチは、表 3.15 に示すような動作をします。一方、図 3.41 に7セグメント LED のセグメント記号、表 3.16 に表示データを示します。



図 3.41 セグメント記号

#### 例題 3-9

表 3.15 と表 3.16 を参考にして、ロータリスイッチから入力した 16 進数のデータ通りの数字を 7 セグメント LED で表示する回路を VHDL で記述しなさい。ただし、動作記述とすること。

#### 解答例

リスト 3.25 に 7 セグメント LED 用デコーダのコードを示します。記述のパターンは、リスト 3.24 のデコーダ と同様です。ロータリスイッチからの入力信号にはベクトル型の RSW (0) ~ RSW (3), 7 セグメント LED への 出力信号には LED (0) ~ LED (7) を宣言しました。case 文では、最後に when others 句の記述を忘れないよう にしましょう。リスト 3.25 では、when others 句に [null] と記述しましたが、たとえば、

\[ \text{when others => LED <= "11111111" ; \]

などのように記述しても結構です。

この例題のような回路を設計する場合、従来のディジタル回路設計法では、表 3.15 や表 3.16 などから回路の動作を論理式で表し、その後に論理式の簡単化などを行って回路の構造を設計する必要がありました。しかし、VHDLによる設計では、ただちに動作記述を行うことができます。

```
library IEEE;
                                                  ロータリスイッチから
use IEEE.STD LOGIC 1164.ALL;
                                                  の4ビット入力
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei3 9 is
  Port ( RSW : in std_logic_vector(3 downto 0);
         LED: out std logic vector(7 downto 0));
                                                           7セグメント LED へ
end rei3 9;
                                                           の8ビット出力
architecture Behavioral of rei3 9 is
begin
        process (RSW)
        begin
                 case RSW is
                        when "0000" => LED <= "00000011";
                        when "0001" => LED <= "10011111";
                        when "0010" => LED <= "00100101";
                        when "0011" => LED <= "00001101";
                        when "0100" => LED <= "10011001";
                        when "0101" => LED <= "01001001" ;
                        when "0110" \Rightarrow LED \Leftarrow "01000001";
```

```
when "0111" => LED <= "00011011";
when "1000" => LED <= "000000001";
when "1001" => LED <= "00001001";
when "1010" => LED <= "00010001";
when "1011" => LED <= "11000001";
when "1100" => LED <= "01100011";
when "1101" => LED <= "01100011";
when "1110" => LED <= "01100001";
when "1111" => LED <= "01100001";
when "1111" => LED <= "01110001";
when others => null;
end case;
end process;
end Behavioral;
```

リスト 3.25 7 セグメント LED 用デコーダのコード (動作記述)

表 3.17 に示すピン割り当てを行い実習で動作を確認してみましょう。

|    | SK OILF P      | nes o ovoc | / B1 / B1 C |            |
|----|----------------|------------|-------------|------------|
|    | 記号             | ピン番号       | 備考          |            |
|    | RSW(0)         | 33         | HEX SV      | W0         |
| 入力 | RSW(1)         | 32         | HEX SV      | W1         |
| 力  | RSW(2)         | 30         | HEX SV      | W2         |
|    | RSW(3)         | 29         | HEX SV      | <b>W</b> 3 |
|    | LED(0)         | 50         |             | dp         |
|    | LED(1)         | 61         |             | g          |
|    | <i>LED</i> (2) | 60         |             | f          |
| 出力 | LED(3)         | 58         | LED 4       | е          |
| 力  | LED(4)         | 56         | (LED D)     | d          |
|    | LED(5)         | 55         |             | С          |
|    | LED(6)         | 53         |             | b          |
|    | <i>LED</i> (7) | 52         |             | a          |

表 3.17 例類 3-9 のピン割り当て

## ▶3.3.3 マルチブレクサとデマルチブレクサ

マルチプレクサ (multiplexer) は、セレクタ (selector) ともよばれ、複数のデータの中から一つのデータを選択する回路です。入力データ数 2''=m の中から n ビットの選択信号線を使用して一つの出力を選択する回路を  $m\times 1$  マルチプレクサといいます。図 3.42 に、 $4\times 1$  マルチプレクサの例を示します。



図 3.42 4 × 1 マルチプレクサ

## 例題 3-10

4×1マルチプレクサを VHDL で記述しなさい。ただし、動作記述とすること、

#### 解答例

リスト3.26 に、4×1マルチプレクサのコードを示します。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
                                                    入力データ4ビット
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
                                                     選択信号2ピット
entity rei3 10 is
  Port ( A : in std logic vector(3 downto 0);
         S : in std_logic_vector(1 downto 0);
         F : out std logic);
end rei3 10;
                                             出力データ1ビット
architecture Behavioral of rei3 10 is
begin
         process(A,S)
         begin
                case S is
                          when "00" \Rightarrow F <= A(0);
                          when "01" \Rightarrow F <= A(1);
                          when "10" \Rightarrow F \iff A(2);
                          when "11" \Rightarrow F <= A(3);
                         when others => null;
                 end case;
        end process;
end Behavioral;
```

リスト 3.26 4×1 マルチプレクサのコード(動作記述)

表 3.18 に示すピン割り当てを行い実習で動作を確認してみましょう。表 3.18 では、4 ビットの入力信号 A (3)  $\sim A$  (0) に、HDLトレーナーのロータリスイッチを割り当てています。たとえば、表 3.19 に示すように、ロータリスイッチを「9」の位置に設定した場合の入力 A (3)  $\sim A$  (0) は「1001」となり、2 ビットの選択信号に割り当てた SW1 と SW2 の操作によって、A (3)  $\sim A$  (0) のいずれかが選択されて F へ出力されます。ここでも、HDLトレーナーのプッシュスイッチ SW1 と SW2 は押した場合に信号「0」、7 セグメント LED は信号「0」で点灯することに注意しましょう。

| 表 3.18 | 列題 3-10 | のピン割り当て |
|--------|---------|---------|
|--------|---------|---------|

|    | 記号      | ピン番号 | 備考       |
|----|---------|------|----------|
|    | A(3) 33 |      | HEX SW3  |
|    | A(2)    | 32   | HEX SW2  |
| 入力 | A(1)    | 30   | HEX SW1  |
| 力  | A(0)    | 29   | HEX SW0  |
|    | S(1)    | 34   | SW1      |
|    | S(0)    | 35   | SW2      |
| 出力 | F       | 61   | LED4 の g |

表 3.19 4×1マルチプレクサの動作例

| 位置 | A(3) | A(2) | A(1) | A(0) | S(1) | S(0) |   | F    |
|----|------|------|------|------|------|------|---|------|
|    |      |      |      |      | 0    | 0    | 1 | A(0) |
| 9  | 1    | 0    | 0    | 1    | 0    | 1    | 0 | A(1) |
|    |      |      |      |      | 1    | 0    | 0 | A(2) |
|    |      |      |      |      | 1    | 1    | 1 | A(3) |

デマルチプレクサ (demultiplexer) は、1ビットの入力データを複数ビットの出力線の中のい ずれかに出力する回路です。つまり、マルチプレクサとは逆の働きをする回路だと考えることが できます。nビットの選択信号線を使用して、1ビットの入力を $2^n = m$ ビットの出力線へ出力 する回路を1×mデマルチプレクサといいます。図3.43に、1×4デマルチプレクサの例を示 します.



図 3.43 1 × 4 デマルチプレクサ

1×4デマルチプレクサを VHDL で記述しなさい。ただし、動作記述とすること、

#### 解客例

リスト 3.27 に、1 × 4 デマルチプレクサのコードを示します。case 文を用いて when 句で出力 F に代入する データを選択しています。出力 F は、4 ビットのベクトル型で宣言していますので、出力 F に入力 A を代入する 場合には連接演算子を用いて同じ4ビット幅にしていることに注意してください。

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
                                                      入力データ1ビット
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei3 11 is
                                                       選択信号2ピット
  Port ( A : in std logic; -
         S : in std_logic_vector(1 downto 0);
         F : out std_logic vector(3 downto 0)); <
                                                     出力データ4ビット
end rei3 11;
architecture Behavioral of rei3_11 is
                                                       4ビットのデータ
begin
                                                       として代入
         process (A,S)
         begin
                 case S is
                         when "00" => F <= "000" & A ;
                        when "01" \Rightarrow F <= "00" & A & '0';
                         when "10" => F <= '0' & A & "00";
                         when "11" \Rightarrow F <= A & "000";
                         when others => null ;
                 end case ;
         end process ;
end Behavioral;
```

リスト 3.27 1 × 4 デマルチプレクサのコード (動作記述)

たとえば、リスト 3.28 のような、出力 F の選択された 1 ピットのみに入力 A を代入するコードを考えてみましょう。このコードでは、図 3.44 に示すように、代入の行われなかった出力 F の上位 3 ピットの値が不定(0 か 1 かが定まらない状態)となってしまいます。したがって、論理合成を行うと「WARNING」メッセージが出ます。誤動作の原因となる可能性が高いので、このような記述は避けましょう。

when "00" => 
$$F(0)$$
 <= A;  
 $F(3)$   $F(2)$   $F(1)$   $F(0)$   
? ? ? A

図 3.44 出力 Fへの代入

```
悪いコードの例
```

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei3 11 is
 Port ( A : in std logic;
         S : in std logic vector(1 downto 0);
         F : out std logic vector(3 downto 0));
end rei3 11;
                                               代入されなかったビット
architecture Behavioral of rei3 11 is
                                               の値は「不定」となる
begin
         process (A, S)
         begin
                 case S is
                         when "00" \Rightarrow F(0) <= A;
                         when "01" \Rightarrow F(1) <= A;
                         when "10" \Rightarrow F(2) <= A;
                         when "11" => F(3) \le A;
                         when others => null;
                 end case ;
         end process ;
end Behavioral;
```

リスト 3.28 出力 Fの 1 ピットのみに入力 A を代入するコード

リスト 3.28 のコードを用いて、表 3.20 に示すビン割り当てを行い実習で動作を確認してみましょう。

| 記号 |              | ピン番号 | 備考     |
|----|--------------|------|--------|
| 入力 | A            | 37   | SW4    |
|    | S(1)         | 34   | SW1    |
|    | S(0)         | 35   | SW2    |
| 出力 | <b>F</b> (3) | 97   | LED1のg |
|    | <b>F</b> (2) | 85   | LED2のg |
|    | F(1)         | 74   | LED3のg |
|    | F(0)         | 61   | LED4のg |

表 3.20 例類 3-11 のピン割り当て

## ▶ 演習問題 3

- 3.1 つぎのデータ型の違いについて説明しなさい。
  - 1 std\_logic
  - ② 「std\_logic\_vector」
- 3.2 シーケンシャル文とコンカレント文の違いについて説明しなさい。
- 3.3 process 文のセンシティピティリストについて説明しなさい。
- 3.4 構造記述と動作記述について説明しなさい。
- **3.5** 図 3.45 は、3 ビットデータの一致を調べる回路である。この回路を VHDL で構造記述したリスト 3.29 の① ~⑧に適当な語句を答えなさい。



図 3.45 3 ピット一致回路

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;
entity syo3 5 is
   Port ( A : 1);
          E: 2;
          C: (3);
          F: 4);
end syo3 5;
architecture Behavioral of syo3 5 is
          ⑤ X,Y : std logic ;
(6)
          X \le A and B and C;
          Y <= (7)(A or B or C);
          F <= (8);
end Behavioral;
リスト 3.29 3 ピット一致回路のコード (構造記述)
```

**3.6** 図 3.45 に示した 3 ビット - 致回路の VHDL コードを動作記述しなさい。ただし、入力データはベクトル型 を使用すること。

# 第4章 順序回路の設計

順序回路は、入力の組合せに加えて、回路の内部状態がどのようになっているかで出力が決まります。順序回路の中心は、フリップフロップとよばれるラッチ回路です。フリップフロップ(flip-flop)とは、「パタンパタン」という音や、ピーチサンダルのことを表す英語です。この意味のように、フリップフロップは、二つの安定状態をもち、何かの信号をきっかけにして、一方の安定状態から他方の安定状態に遷移する回路です。

この章では、非同期式と同期式の違いや各種のフリップフロップの動作について確認した後、シフトレジスタやカウンタなどの順序回路を設計しましょう. 順序回路の設計では、主に同期式回路の動作記述が用いられます.



# 4.1 フリップフロップの設計

順序回路は、内部にラッチ(latch)回路(記憶回路ともいいます)を含みます。ラッチ回路としては、フリップフロップを使用します。この節の初めでは、順序回路が動作するタイミングやクロックのタイミングなどについて理解しましょう。その後、各種のフリップフロップをVHDLコードで記述する方法などについて学びましょう。

## ▶4.1.1 非同期式と同期式

0

複数のフリップフロップ(以下 FF と省略表記します)を使用して構成した回路の動作を考えましょう. たとえば,3 個の FF を直列に接続(カスケード接続)して動作させる場合,図 4.1 (a) に示すように, $FF_1 \rightarrow FF_2 \rightarrow FF_3$  と順次動作させる方式を非同期式(asynchronous)といいます.この場合は, $FF_1$  が動作してデータを出力してから  $FF_2$  がそのデータを受け取って動作し,その後同様に  $FF_3$  が動作します. つまり,ドミノ倒しのようなイメージで動作します.



図 4.1 動作のタイミング

一方、図 4.1 (b) に示すように、 $FF_1$ 、 $FF_2$ 、 $FF_3$  を同時に動作させる方式を同期式(synchronous)といいます.この場合は、 $FF_2$  が動作する際の入力データは、 $FF_1$  が前回の動作によって出力していたデータを取り込みます.同様に、 $FF_3$  は  $FF_2$  が前回の動作によって出力していたデータを取り込みます.

非同期式では、各FFの動作時間が累積していきますので、多くのFFを使用した場合には、 最終的な出力結果を得るまでに長い時間が必要となってしまいます。しかし、同期式では、すべ てのFFが一斉に動作するため、出力をすぐに得ることができます。また、同期式は、ハザード (hazard) とよばれるノイズの影響を受けにくいなど、動作の信頼性が非同期式よりも高いこと が利点です。このため、ある程度以上の複雑さをもったディジタル回路では、同期式が主流と なっています。本書でも、同期式の順序回路の設計法を主体に説明を行います。

## ▶ 4.1.2 クロックの記述

0

クロック (clock) は、回路が動作するタイミングのきっかけになる信号です。通常は、図 4.2 に示すような方形波の立ち上りエッジ(ポジティブエッジ)または、立ち下りエッジ(ネガティブエッジ)を使用します。つまり、たとえばポジティブエッジを指定した場合には、方形波が 0 から 1 に立ち上がる瞬間ごとに、回路が 1 回動作します。



図 4.1 に示した非同期式と同期式の回路では、たとえば、クロック入力の仕方が図 4.3 のようになります。同期式では、有効な 1 個のクロックですべての FF が一斉に動作します。



図 4.3 クロック入力の例 (ポジティプエッジ)

VHDLでは、クロック *CLK* のポジティブエッジとネガティブエッジをつぎのように記述します。通常は、この記述を process 文と組合せて使用しますが、具体的な使用法については後で学びます。

CLK' event and CLK = '1'……ポジティブエッジ CLK' event and CLK = '0'……ネガティブエッジ

## ▶ 4.1.3 *D*-FF

0

図 4.4 に,D-FF の図記号などを示します.D-FF は,有効なクロックが入力されたときに,入力 D のデータを取り込んで出力 Q から出力します.D-FF の D は,ディレイ(delay:遅れる)という意味に由来します.クロックのポジティブエッジとネガティブエッジの図記号についても確認しておいてください。



図 4.4 D-FF

#### 例题 1

図 4.5 に示す D-FF を VHDL で記述しなさい.



図 4.5 ネガティブエッジ型 D-FF

#### 解答例

ネガティブエッジ型の D-FFです。リスト 4.1 に、コードの記述例を示します。process 文のセンシティビティリストに記述したクロック CLK が変化すると、if 文の判定が行われます。そこで、ネガティブエッジのときに if 文の条件式が成立し、入力 D のデータがそのまま出力 Q から出力されます。

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei4 1 is
    Port ( D : in std logic;
          CLK : in std_logic;
          Q : out std_logic);
end rei4_1;
                                                        CLKのネガティブ
architecture Behavioral of rei4 1 is
                                                        エッジで if 文の条
                                                        件が成立する
       process (CLK)
             begin
                     if (CLK'event and CLK='0') then
                           Q <= D ;
                     end if ;
       end process ;
end Behavioral:
```

リスト 4.1 D-FF のコード

論理合成を行い、「View RTL Schematic」を実行すると、図 4.6 に示す回路が構成されたことが確認できます。



図 4.6 構成された回路

HDLトレーナーを用いて,表 4.1 に示すピン割り当てによって実習を行います. 初めに,プッシュスイッチ SW1 で入力 D の値を決めた後,プッシュスイッチ SW2 を操作してクロック CLK を入力し,7 セグメント LED4 の点灯によって出力 Q の値を確認しましょう.

|    | X 4.1 PI | EST IVICI | 司リコく   |  |
|----|----------|-----------|--------|--|
| 1  | 己 号      | ピン番号      | 備考     |  |
| 入  | D        | 34        | SW1    |  |
| 分为 | CLK      | 35        | SW2    |  |
| 出力 | Q        | 61        | LED4のg |  |

**奏 4.1** 例題 4-1 のピン割り当て

FF には、リセット端子やセット端子の付いたタイプがあります。図 4.7 に、リセット端子付きの D-FF の図記号を示します。この D-FF は、クロック CLK のポジティブエッジで動作し、リセット RESET 端子(負論理)に0 が入力されるとリセット信号が有効になります。

ただし、リセット動作には、非同期リセットと同期リセットがあることに注意してください。 非同期リセットは、有効なリセット信号がリセット端子に入力されると、すぐに出力 Q がリ



図 4.7 リセット端子付き D-FF



図 4.8 非同期リセットと同期リセット

セット (0 が出力) されます。したがって、非同期リセットのことを強制リセットとよぶこともあります。一方、同期リセットでは、有効なリセット信号をリセット端子に入力しても、それだけではリセット動作は起こりません。有効なリセット信号の入力に加えて、有効なクロック信号が入力された場合に、リセット動作が実行されます。非同期リセットと同期リセットの動作の違いを、図 4.8 のタイムチャート例で確認してください。また、図 4.7 の図記号からは、非同期リセットと同期リセットを区別することはできませんので注意が必要です。

## 例頭1世

図 4.9 に示す D-FF を VHDL で記述しなさい。ただし、リセット方式が非同期と同期それぞれのコードを記述しなさい。



図 4.9 リセット端子付き D-FF

## 扇答明

非同期リセット端子付き FF のコードをリスト 4.2、同期リセット端子付き FF のコードをリスト 4.3 に示します。

```
library IEEE;
                                                    library IEEE;
use IEEE.STD LOGIC 1164.ALL;
                                                    use IEEE.STD LOGIC 1164.ALL;
                                                    use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC ARITH.ALL;
                                                    use IEEE.STD_LOGIC_UNSIGNED.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL:
                                                    entity rei4 2 2 is
entity rei4 2 1 is
                                                        Port ( D : in std logic;
    Port ( D : in std logic;
                                                               CLK : in std logic;
          CLK : in std logic;
                                                               RESET : in std logic;
          RESET : in std logic;
                                                               Q : out std logic);
          Q : out std_logic);
                                                    end rei4 2 2;
end rei4 2 1;
                                                    architecture Behavioral of rei4 2 2 is
architecture Behavioral of rei4 2 1 is
                                                    begin
begin
                                                               process (CLK)
                                                               begin
          process (CLK, RESET)
                                                                        if CLK'event and CLK='1' then
          begin
                                                                               if RESET = '0' then
                  if RESET = '0' then
                                                                                       Q <= '0';
                          0 <= 101;
                                                                               else
                  elsif CLK'event and CLK='1' then
                                                                                       O <= D ;
                          Q <= D ;
                                                                               end if ;
                  end if ;
                                                                       end if :
          end process ;
                                                               end process;
end Behavioral;
                                                    end Behavioral;
```

リスト 4.2 非同期リセット D-FF のコード

リスト 4.3 同期リセット D-FF のコード

リスト 4.3 の同期リセット D-FF では、process 文のセンシティビティリストにリセット信号 RESET を記述する必要がありません。また、if 文での判定順序が  $CLK \to RESET$  となっていることを確認してください。非同期リセット、同期リセットとも、表 4.2 に示すピン割り当てによって実習を行い、動作の違いを比較しましょう。

| i i | 己号    | ピン番号 | 備考     |  |
|-----|-------|------|--------|--|
|     | D     | 34   | SW1    |  |
| 入力  | CLK   | 35   | SW2    |  |
|     | RESET | 36   | SW3    |  |
| 出力  | Q     | 61   | LED4 O |  |

表 4.2 例類 4-2 のピン割り当て

FFには、イネーブル端子の付いたタイプがあります。イネーブル (enable) とは、動作を可 能にするという意味をもちます。イネーブル端子に有効な信号を入れているときにはクロック入 力を受け付けますが、それ以外では出力 Q を保持したまま動作しません、リスト 4.4 に、正論理 のイネーブル端子付き D-FF(クロックはネガティブエッジ型)のコード(process 文)を示し ます.

```
process (CLK)
  begin
          if (CLK'event and CLK = '0') then
                  if (ENABLE = '1') then
                          Q <= D ;
                  end if ;
          end if ;
  end process ;
リスト 4.4 イネーブル端子付き D-FF のコード (process 文)
```

## 例題 4-3

図 4.10 に示すイネーブル端子付きの D-FF を VHDL で記述しなさい。ただし、同期リセット 型とする.



図 4.10 イネーブル端子付き D-FF

## 解其例

同期リセット端子(負論理)とイネーブル端子(正論理)をもったネガティブエッジ型のクロックで動作する D-FF に関する例題です。この D-FF のコードをリスト 4.5。フローチャートを図 4.11 に示します。

これまで使用してきた、CLK、RESET、ENABLE などの記号は、VHDLの予約語ではありませんので、他の記 号に変更することも可能です。

表 4.3 に示すピン割り当てを行って実習で動作を確認しましょう。イネーブル端子への入力はロータリスイッチの最下位ビット (HEXSWO) を割り当てました。ロータリスイッチの表示が0でイネーブル無効、1で有効となります。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
                                                                 process (CLK)
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
                                                                  イガティブエ
                                                             No
entity rei4 3 is
   Port ( D : in std logic;
                                                                         Yes
          CLK : in std logic;
          ENABLE : in std logic;
                                                             No
                                                                    ENABLE
          RESET : in std logic;
                                                                     1?
          Q : out std logic);
                                                                         Yes
end rei4 3;
                                                                    RESET
                                                                              No
architecture Behavioral of rei4 3 is
                                                                     0?
        process (CLK)
                                                                         Yes
        begin
                                                                   Q \leftarrow 0
                                                                                  Q \leftarrow D
                if (CLK'event and CLK = '0') then
                          if (ENABLE = '1') then
                                 if (RESET = '0') then
                                          0 <= '0';
                                                                  end process;
                                  else
                                          Q <= D ;
                                                             図 4.11 イネーブル端子付き
                                  end if;
                                                                     D-FF のフローチャート
                         end if ;
                end if ;
        end process ;
end Behavioral:
```

リスト 4.5 イネーブル端子付き D-FF のコード

ピン番号 備老 D34 SW1 CLK35 SW2 RESET 36 SW3 **ENABLE** ロータリSWのHEXSW(1) 出 61 LED4のg

表 4.3 例題 4-3 のピン割り当て

## ▶ 4.1.4 RS-FF

RS-FF は、セット端子 S とリセット端子 R をもった FF です。図 4.12 に、ポジティブエッジ型のクロック端子付き RS-FF の図記号などを示します。



図 4.12 クロック端子付き RS-FF

## 例題 4-4

図 4.13 に示すクロック端子付き RS-FF を VHDL で記述しなさい。



図 4.13 ネガティブエッジ型 RS-FF

### 解答例

クロック CLK のネガティブエッジで動作する RS-FF です。リスト 4.6 に、コードを示します。入力端子 S と R を、signal 文で宣言した 2 ビットベクトル型の内部信号 INPUT に代入しています。そして、クロック CLK の立ち下り時に case 文を用いて出力 Qへの代入処理を行っています。表 4.4 示すピン割り当てを行って実習で動作を確認しましょう。

表 4.4 例題 4-4 のピン割り当て

| J. | 1. 号 | ピン番号 | 備考     |
|----|------|------|--------|
|    | S    | 34   | SW1    |
| 入力 | R    | 35   | SW2    |
|    | CLK  | 36   | SW3    |
| 出力 | Q    | 61   | LED4のg |

## library IEEE;

use IEEE.STD\_LOGIC\_1164.ALL;

use IEEE.STD\_LOGIC\_ARITH.ALL;

use IEEE.STD\_LOGIC\_UNSIGNED.ALL;

## entity rei4 4 is

Port ( S : in std logic;

R : in std\_logic; CLK : in std\_logic; Q : out std logic);

```
end rei4 4;
                                                         内部信号 INPUT を
                                                         ベクトル型で官言
architecture Behavioral of rei4 4 is
        signal INPUT : std logic vector(1 downto 0) ;
       INPUT <= (S & R) ;
       process (CLK)
                                                         出力

〇への代理処理
       begin
               if (CLK'event and CLK = '0') then
                        case INPUT is
                                when "01" => 0 <= '0';
                                when "10" => 0 <= '1' :
                                when others => null ;
                        end case ;
               end if ;
       end process ;
end Behavioral:
```

リスト 4.6 クロック端子付き RS-FF のコード

## ▶ 4.1.5 *JK-FF*

Q

RS-FF は、R=S=1の入力を行うと出力 Qが不定になるため、この入力を禁止しています。 JK-FF は、この点を改良した FF であり、J=K=1の入力を行うと出力 Q は反転動作をします。 JK-FF の端子 J と K は、それぞれ RS-FF の端子 S と R に対応します。 図 4.14 に、ネガティブエッジ型のクロック端子付き JK-FF の図記号などを示します。



図 4.14 クロック付き JK~FF

## 例组(二

図 4.15 に示すクロック端子付き JK-FF を VHDL で記述しなさい。



図 4.15 クロック端子付き JK-FF

## 解答例

クロック CLK のネガティブエッジで動作する JK - FF です.出力端子は,Q とその反転 Q の 2 本です.リスト 4.7 に、この JK-FF のコードを示します. 基本的な記述法は、リスト 4.6 の RS-FF のコードと同じです. 入力端 子 / と K を, signal 文で宣言した 2 ビットベクトル型の内部信号 INPUT に代入しています。そして, クロック CLK の立ち下り時に case 文を用いて内部信号 WORK への代入処理を行っています。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei4 5 is
  Port ( J : in std logic;
         K : in std_logic;
         CLK : in std logic;
         Q : out std logic;
                                                                内部信号 INPUT
         Q NOT : out std logic);
                                                                の宣言
end rei4 5;
architecture Behavioral of rei4 5 is
        signal INPUT : std logic vector(1 downto 0) ;
                                                                内部信号 WORK
        signal WORK : std logic ;
                                                                の宣言
begin
       INPUT <= (J & K);
       process (CLK)
        begin
                                                  内部信号 WORK
        if (CLK'event and CLK = '0') then
                                                  への代入処理
                case INPUT is
                        when "01" => WORK <= '0';
                        when "10" => WORK <= '1';
                        when "11" => WORK <= not WORK;
                        when others => null ;
                end case ;
        end if ;
                                  出力 Q と Q_NOTへ
   end process ;
                                  の代入処理
   Q <= WORK ;
   Q NOT <= not WORK ;
end Behavioral;
```

リスト 4.7 クロック端子付き JK-FF のコード

出力信号は、直接的に not などの操作を記述することはできません。つまり、リスト 4.7 の出力への代入処理に おいて、「Q\_NOT <= not Q;」とは記述できないのです。したがって、内部信号 WORK を宣言して、「Q\_NOT <= not WORK;」のように記述しています.表 4.5 に示すピン割り当てを行って実習で動作を確認しましょう.

| 記号 |       | ピン番号 | 備考       |
|----|-------|------|----------|
|    | J     | 34   | SW1      |
| 入力 | K     | 35   | SW2      |
|    | CLK   | 36   | SW3      |
| 出  | Q     | 74   | LED3 ∅ g |
| 出力 | Q_NOT | 61   | LED4のg   |

A E MIBE A E OUS SOIL WY

この実習では、入力にJ=K=1を設定してクロック信号 CLKを有効にした際、つまり HDLトレーナーでは、プッシュスイッチ SW1 と SW2 を難した状態で SW1 を押した場合に、時として不安定な動作をすることがあります。不安定な動作とは、7 セグメント LED の点灯がうまく反転しないことを指します。これは、プッシュスイッチを操作する際に生じるノイズ(チャタリングといいます)の影響です。プッシュスイッチを1回しか押していないつもりでも、チャタリングが発生して複数回のクロックが入力されてしまうためです。チャタリングはディジタル回路の誤動作の原因となりますので、信頼性の高い回路を設計する場合には、チャタリング除去回路を設ける必要があります。

## 例題 4-6

図 4.16 に示すイネーブル端子付き JK-FF を VHDL で記述しなさい。



図 4.16 イネーブル端子付き JK-FF

## 所答例

クロック CLK のポジティブエッジで動作する正論理のイネーブル端子付き JK-FF です。リスト 4.8 に,この JK-FF のコードを示します。リスト 4.7 と比較して理解するとよいでしょう。続いて,表 4.6 に示すピン割り当てを行って実習で動作を確認しましょう。イネーブル端子への入力はロータリスイッチの最下位ピット (HEXSWO) を割り当てました。ロータリスイッチの表示が0でイネーブル無効,1で有効となります。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei4 6 is
  Port ( J : in std logic;
        K : in std logic;
        CLK : in std logic;
        ENABLE : in std logic;
        Q : out std logic);
end rei4 6;
                                                               内部信号の宣言
architecture Behavioral of rei4 6 is
        signal INPUT : std logic vector(1 downto 0) ;
        signal WORK : std logic ;
begin
        INPUT <= (J & K);
       process (CLK)
       begin
               if (CLK'event and CLK = '1') then
                                                         イネーブル信号の判定
                        if (ENABLE = '1') then
                                                         JK-FFの動作
                                case INPUT is
                                        when "01" => WORK <= '0';
                                        when "10" => WORK <= '1';
                                        when "11" => WORK <= not WORK;
                                        when others => null ;
```



リスト 4.8 イネーブル端子付き JK-FF のコード

| 表 4.6 例題 4-6のピン割り | り当て |  |
|-------------------|-----|--|
|-------------------|-----|--|

|    | 記号     | ピン番号 | 備 考            |
|----|--------|------|----------------|
|    | J      | 34   | SW1            |
| 入  | K      | 35   | SW2            |
| 力  | CLK    | 36   | SW3            |
|    | ENABLE | 33   | ロータリSWのHEXSW 0 |
| 出力 | Q      | 61   | LED4 Ø g       |

## ▶ 4.1.6 *T*-FF

T-FF は,有効な信号が入力されるたびに,出力 Q の値を反転する FF です.T-FF の T は,トグル(toggle:切り替える)という意味に由来しています.図 4.17 に,T-FF の図記号などを示します.



☑ 4.17 *T*-FF

## 例題 4-7

図 4.18 に示す T-FF を VHDL で記述しなさい。



図 4.18 ポジティプエッジ型 T-FF

## 報答例

入力Tのポジティブエッジで動作するT-FFです。リスト4.9に、このT-FFのコードを示します。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei4_7 is
 Port ( T : in std_logic;
        Q : out std logic;
         Q NOT : out std logic);
end rei4 7;
                                          内部信号 WORK の宣言
architecture Behavioral of rei4_7 is
        signal WORK : std logic ;
begin
        process(T)
                                                       WORKの反転処理
        begin
               if (T'event and T = '1') then
                        WORK <= not WORK ;
               end if ;
        end process ;
                                             出力 Q, Q_NOTへの
        Q <= WORK ;
                                             代入処理
        Q NOT <= not WORK ;
end Behavioral;
```

リスト 4.9 ポジティプエッジ型 T-FF のコード

論理合成を行い、「View RTL Schematic」を実行すると、図 4.19 に示すように、D-FF を用いた T-FF 回路が構成されたことが確認できます。



図 4.19 構成された回路

HDLトレーナーを用いて、表 4.7 に示すピン割り当てによって実習を行いましょう。

| 記 号 |       | ピン番号 | 備考       |
|-----|-------|------|----------|
| 入力  | T     | 34   | SW1      |
| 出   | Q     | 74   | LED3のg   |
| 力   | Q_NOT | 61   | LED4 の g |

表 4.7 例題 4-7 のピン割り当て

この実習では、例題 4-5 で説明したチャタリングが発生していることを意識しながら実習することも大切です。 プッシュスイッチ操作時に発生するチャタリングの影響によって、正しい動作をしない場合があるはずです。 確実なプッシュスイッチ操作を心がければチャタリングによる誤動作が減少することなどを体験してください。 また、HDLトレーナーのプッシュスイッチは、押したときに信号が $1 \rightarrow 0$ 、離したときに信号が $0 \rightarrow 1$  に変化します。 したがって、この実習で構成したボジティブエッジ型 T - FF では、プッシュスイッチを離したときに出力(7セグメント LED の点灯)が変化することを確認しましょう。

# 4.2

# シフトレジスタの設計

カスケード接続した複数の FF がクロック信号に同期して、データを 1 ビットずつ右方向また は左方向に移動させる回路をシフトレジスタ (shift register) といいます。電光掲示板に表示さ れた文字が、流れるように移動する回路もシフトレジスタを応用したものです。ここでは、 VHDLによってシフトレジスタを構成する実習を行いましょう。

## ▶4.2.1 シリアルイン・バラレルアウトのシフトレジスタ

0

シフトレジスタは、入力と出力がシリアル(serial:直列)かパラレル(parallel:並列)かによって分類することができます。例として、図 4.20 にシリアルイン・パラレルアウトの 4 ビットシフトレジスタの構成とそのタイムチャート例を示します。



図 4.20 シリアルイン・パラレルアウトのシフトレジスタ

このシフトレジスタは、クロック信号 *CLK* のポジティブエッジ時ごとにデータを1 ビットずつ右方向  $(FF_0 \to FF_1 \to FF_2 \to FF_3)$  へ移動していきます。使用している D- FF は、同期リセッ

ト端子付きでクロックのポジティブエッジで動作するタイプです。

## 例題 4-8

図 4.21 に示す 4 ビットのシリアルイン・パラレルアウトのシフトレジスタを VHDL で記述しなさい。ただし。D-FF は同期リセット型とすること。



図 4.21 4 ピットのシリアルイン・パラレルアウトのシフトレジスタ

## 所答例

クロック入力 *CLK* のポジティブエッジで動作するシフトレジスタです。リスト 4.10 に、このシフトレジスタのコードを示します。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei4 8 is
 Port ( D : in std logic;
        CLK : in std logic;
        RESET : in std logic;
        Q : out std_logic vector(3 downto 0));
end rei4 8;
architecture Behavioral of rei4 8 is
        signal WORK : std_logic_vector(3 downto 0) ;
begin
                                           ポジティブエッジの検出
        process (CLK)
        begin
        if (CLK'event and CLK = '1') then
                 if (RESET = '0') then
                                                    同期リセット
                          WORK <= "0000";
                 else
                                                    データを右にシフト
                          WORK(0) <= D ;
                                                    する
                          WORK(1) <= WORK(0) :
                          WORK(2) <= WORK(1);
                          WORK(3) <= WORK(2);
                 end if ;
        end if ;
        end process ;
                                 出力Qへの代入処理
        Q <= WORK ;
end Behavioral:
```

リスト 4.10 シリアルイン・パラレルアウトのシフトレジスタのコード

出力 Q と内部信号 WORK は、ベクトル型で宣言しました。この例題において、表 4.8 に示すようなピン割り当てを行い HDL トレーナーで実習を行うと、チャタリングの影響が強く現れるため動作の確認は困難でした。しかし、実際に実習してみることは、よい経験になることでしょう。

| 100 | 己号    | ピン番号 | 備考       |
|-----|-------|------|----------|
|     | D     | 34   | SW1      |
| 入力  | CLK   | 35   | SW2      |
|     | RESET | 36   | SW3      |
|     | Q(0)  | 97   | LED1のg   |
| 出   | Q(1)  | 85   | LED2のg   |
| 出力  | Q(2)  | 74   | LED3 の g |
|     | Q(3)  | 61   | LED4のg   |

表 4.8 例題 4-8 のピン割り当て

HDLトレーナーには、周波数 4 MHz のセラロック発振子が搭載されています。この発振子からの信号をクロックとして、シフトレジスタを動作させてみましょう。周波数 4 MHz の方形波は、図 4.22 に示すように、 $0.25~\mu s$  の周期 Tで変化します(35ページ、式(2.1)参照)。



この周期でシフトレジスタを動作させたのでは、高速すぎて人の目では確認することができません。したがって、たとえば、セラロックからの方形波が10個人力されるたびに、1個の方形波を出力するような回路を考えます(図 4.23)。このような回路を分周回路といいます。 この例では、4 MHz の方形波は10分の1に分周されることになります。



図 4.23 分周回路の考え方

周波数 4 MHz(4000 kHz)を 1/10 に分周すると 400 kHz になります。 つまり,周期  $0.25\,\mu s$  は 10 倍の  $2.5\,\mu s$  になりますが,これでも人にとっては速すぎます.分周比をさらに大きくして, $1/2^{22}$  にすれば,次式のようにおよそ1s の周期 T' が得られます.

```
T' = (0.25 \times 10^{-6}) \times 2^{22} = 1 \text{ s}
```

この分周回路の VHDL コードの一部(process 文)をリスト 4.11 に示します。セラロックからのクロック信号を内部信号 DD によってカウントしています。そして,DD が  $2^{22}-1$ (1 を引いているのは,0 からカウントしているためです)になるたびに,方形波 CE を 1 個出力しています。

```
-- 分周回路
           22 ビット
process (CLK)
begin
                                          クロック入力ごとに.
   if CLK'event and CLK='1' then
                                          DD に1を加算する
       DD <= DD + '1';
  end if;
end process;
process (DD)
begin
                                                 DD が 2<sup>22</sup>-1 になっ
  if DD = "111111111111111111111" then
                                                 たら1個の方形波
     CE <= '1';
                                                 CE を出力する
  else
     CE <= '0';
  end if;
end process;
```

リスト 4.11 1/2<sup>22</sup> 分周回路のコード

リスト 4.11 の分周回路によって作成した周期 1s の方形波をクロック信号にして、リスト 4.10 のシフトレジスタを動作させてみましょう。図 4.24 にシフトレジスタ実習回路の構成、リスト 4.12 に実習用コードを示します。



図 4.24 シフトレジスタ実習回路の構成

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei4 8 is
 Port ( D : in std_logic;
        CLK : in std logic;
        RESET : in std logic;
        Q : out std logic vector(3 downto 0));
                                                    内部信号の宣言
end rei4 8;
architecture Behavioral of rei4 8 is
       signal WORK: std logic vector(3 downto 0);
       signal DD : std_logic_vector(21 downto 0) ;
       signal CE : std logic ;
begin
                               分周回路のカウンタ部
 -- 分周回路
             22 ピット
process (CLK)
                                   クロックは CLK
begin
  if CLK'event and CLK='1' then
     DD <= DD + '1';
  end if:
end process;
                             分周回路の方形波発生部
process (DD) -
                                 -227
begin
 if DD = "1111111111111111111111" then
    CE <= '1';
  else
    CE <= '0';
  end if;
end process ;
                    シフトレジスタ部
-- シフトレジスタ
                                      クロックは CE
process (CE)
        begin
        if (CE'event and CE = '1') then
                                             同期リセット
                if (RESET = '0') then
                        WORK <= "0000" ;
                else
                        WORK(0) \le D;
                        WORK(1) \le WORK(0);
                        WORK(2) <= WORK(1);
                        WORK(3) <= WORK(2);
                end if ;
        end if ;
        end process ;
                         出力Qへの代入処理
        O <= WORK ;
end Behavioral;
```

リスト 4.12 シフトレジスタ (例題 4-8) の実習用コード

リスト 4.12 のコードを論理合成して「View Synthesis Report」を実行してみましょう。図 4.25 に、Synthesis Report の一部を示します。このコードで使用した FF は、シフトレジスタに 4 個、分周回路に 22 個、つまり合計 26 個であることが確認できます。



図 4.25 Synthesis Report の一部

表 4.9 に示すピン割り当てによって実習を行いましょう。 プッシュスイッチ SW1 を押し続ける(信号 D=0)と 7 セグメント LED の表示が左から右へ順次点灯します。 そして、プッシュスイッチ SW1 を離すと(信号 D=1)と 7 セグメント LED の表示が左から右へ順次消灯します。 また、プッシュスイッチ SW2 を押すと (RESET = 0)、リセット信号が有効になり 4 個の 7 セグメント LED が点灯するはずです。 この実習回路は、同期 リセットなので SW2 は 1 秒(分周後のクロック CE の周期)以上押し続ける必要があります。

| 记号    | ピン番号                            | 備考                                                                                                 |
|-------|---------------------------------|----------------------------------------------------------------------------------------------------|
| CLK   | 22                              | CLK1                                                                                               |
| D     | 34                              | SW1                                                                                                |
| RESET | 35                              | SW2                                                                                                |
| Q(0)  | 97                              | LED1のg                                                                                             |
| Q(1)  | 85                              | LED2 の g                                                                                           |
| Q(2)  | 74                              | LED3 の g                                                                                           |
| Q(3)  | 61                              | LED4のg                                                                                             |
|       | CLK  D  RESET  Q(0)  Q(1)  Q(2) | CLK     22       D     34       RESET     35       Q(0)     97       Q(1)     85       Q(2)     74 |

表 4.9 リスト 4.12 のピン割り当て

## ▶ 4.2.2 バラレルイン・シリアルアウトのシフトレシスタ

図 4.26 に、パラレルイン・シリアルアウトの 4 ピットシフトレジスタの構成とそのタイムチャート例を示します。使用している D-FF は、同期セット・リセット端子付きで、クロックがポジティブエッジで動作するタイプです。



(b) タイムチャート例

図 4.26 パラレルイン・シリアルアウトのシフトレジスタ

このシフトレジスタは、信号 LOAD が1のときクロック信号 CLK に同期して4ビットのパラ レルデータ ABCD を各 FF に取り込みます。その後、クロック信号のポジティブエッジ時に各 FF のデータを右方向に1ビットずつシフトしていきます。つまり、出力 Q からは、入力された パラレルデータが  $D \to C \to B \to A$  の順でシリアルに出力されます.

## 例照 4-9

図 4.27 に示す 4 ビットのパラレルイン・シリアルアウトのシフトレジスタと同様の動作をする 同路を VHDL で記述しなさい。ただし、使用する D-FF は、同期セット・リセット型とすること。



図 4.27 4 ピットのパラレルイン・シリアルアウトのシフトレジスタ

## 解答例

人力データ $D_LIN(0)\sim(3)$  は,LOAD信号が0のときにクロック信号に同期して取り込まれます. $FF_3$ の出力Qは,パラレル入力をシリアルに出力する端子です.この出力Qは, $FF_0$ の入力 $D_0$ にフィードバック接続されていますので,出力Qからは入力データ $D_LIN(0)\sim(3)$ が繰り返し出力されます.リスト4.13に,このシフトレジスタのコードを示します.

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity rei4 9 is
  Port ( D_IN : in std logic vector(3 downto 0);
        CLK : in std logic;
        LOAD : in std logic;
        Q : out std logic );
end rei4 9;
                                                           内部信号の宣言
architecture Behavioral of rei4 9 is
       signal WORK : std_logic_vector(3 downto 0) ;
begin
process (CLK)
                                                  CLKに同期して入力
       begin
                                                  データを取り込む
        if (CLK'event and CLK = '1') then
                if (LOAD = '0') then
                         WORK <= D IN ;
                else
                                                      シフトレジスタの処理
                         WORK(0) \le WORK(3);
                         WORK(1) \le WORK(0);
                         WORK(2) <= WORK(1);
                         WORK(3) <= WORK(2);
             end if ;
       end if ;
                                    シリアル出力Qへの
       end process ;
       O <= WORK(3);
                                    代入処理
end Behavioral;
```

リスト 4.13 パラレルイン・シリアルアウトのシフトレジスタのコード

例題 4-8 と同様に、HDLトレーナーのセラロック 4 MHz を分周回路によって遅くして動作させる実習用コードをリスト 4.14、そのピン割り当てを表 4.10 に示します。パラレル入力データは、ロータリスイッチの出力 4 ピットを使用しています。ロータリスイッチで設定したデータが、およそ 1 秒ごとにシリアルに繰り返して出力される動作を確認してください。入力データの取り込みは、プッシュスイッチ SW1 を押したとき(LOAD=0)に行われます。

```
library IEEE;
                                                表 4.10 リスト 4.14 のピン割り当て
use IEEE.STD LOGIC 1164.ALL;
                                             記号
                                                      ピン番号
use IEEE.STD LOGIC ARITH.ALL;
                                               CLK
                                                        22
                                                              CLK1
use IEEE.STD LOGIC UNSIGNED.ALL;
                                               LOAD
                                                              SW1
entity rei4 9 is
                                              D-IN(0)
                                                              ロータリSWの HEXSW3
 Port ( D_IN : in std_logic_vector
                                              D-IN(1)
                                                              ロータリSWの HEXSW2
  (3 downto 0);
        CLK : in std logic;
                                              D-IN(2)
                                                              ロータリSW の HEXSW1
        LOAD : in std logic;
                                              D-IN(3)
                                                              ロータリSWの HEXSW0
        Q : out std_logic );
                                           出
end rei4 9;
                                                 0
                                                        61
                                                              LED4のg
                                           力
architecture Behavioral of rei4 9 is
       signal WORK : std_logic_vector(3 downto 0) ;
       signal DD : std logic vector(21 downto 0) ;
       signal CE : std logic ;
begin
                                                       分周回路のカウンタ部
 -- 分周回路 22 ビット
                                         クロックは CLK
process (CLK)
begin
  if CLK'event and CLK='1' then
     DD <= DD + '1';
 end if:
                                                      分周回路の方形波発生部
end process;
process (DD)
begin
  if DD = "1111111111111111111111" then
     CE <= '1';
  else
    CE <= '0';
  end if;
                                    シフトレジスタ部
end process ;
-- シフトレジスタ
                                             クロックは CE
process (CE)
       begin
       if (CE'event and CE = '1') then
                                                             LOAD = 0 でデータ入力
               if (LOAD = '0') then
                        WORK <= D IN ;
                else
                        WORK(0) <= WORK(3);
                         WORK(1) <= WORK(0);
                        WORK(2) <= WORK(1);
                         WORK(3) <= WORK(2);
                end if ;
        end if ;
                                   シリアル出力のへの
       end process ;
                                   代入処理
       Q <= WORK(3);
end Behavioral;
```

リスト 4.14 シフトレジスタ (例題 4-9) の実習用コード

# カウンタの設計

カウンタ (counter) は、特性方程式や励起表、カルノー図などを用いて設計することができ ます. しかし、VHDLを用いて動作記述すれば、任意のn進カウンタをより簡単に設計するこ とが可能となります. ここでは、VHDLによるカウンタの基本的な記述方法を実習しましょう.

## ▶ 4.3.1 同期式 n 進カウンタ

図 4.28 に、JK-FF を用いた同期式 5 進カウンタの回路などを示します。同期式カウンタは、 クロック信号 CLK に同期して、すべての FF が一斉に動作します。また、n 進カウンタでは、有 効なクロック信号 CLK が入力されるたびに、出力  $Q_0 \sim Q_{n-1}$  の値は 1 ずつカウントアップし (アップカウンタの場合), n 個目のクロック信号ですべてリセットされます。そして、つぎのク ロック信号から,再びカウントアップを繰り返します.n進カウンタを構成するためには、2<sup>\*</sup>≥ nを満たすk個の FF を必要とします。図 4.28 で、5 進カウンタの動作を確認してください。



特性方程式や励起表。カルノー図などを用いる場合には、2°進カウンタが任意のn進カウン タよりも簡単に設計できますが、VHDLを用いれば、何進カウンタであってもほぼ同様のパ ターンで記述することができます. リスト 4.15 に, VHDL を用いた同期式 8 進カウンタ (2" 進 カウンタ) のコードを示します. VHDLでは、出力 Q に対して  $\lceil Q \leftarrow Q + '1' \mid 0$  のような直接 代入処理はできません、したがって、内部信号 WORK を用いてカウントアップの処理を行って います、最後に、内部信号 WORK を出力 Q に代入する処理を記述することを忘れないでくださ い. 2" 進カウンタを記述する場合には、n ビットの出力とそれに対応する内部信号を宣言しま 7

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity list15 is
  Port ( CLK : in std logic;
         Q : out std logic vector(2 downto 0));
                                                   内部信号 WORK
 end list15;
                                                   の宣言
architecture Behavioral of list15 is
       signal WORK : std logic vector(2 downto 0) ;
begin
                                                  ネガティブエッジで動作
process (CLK)
  begin
   if(CLK'event and CLK='0') then
                                                   カウントアップ
                  WORK <= WORK + '1' ;
    end if;-
                                                  出力のへの代入処理
  end process;
   Q <= WORK ;
 end Behavioral:
```

リスト 4.15 同期式 8 進力ウンタ (2" 進力ウンタ) のコード

·方、任意のn進カウンタを記述する場合には、カウンタ処理を行う前にif文を用いた判定 を行い。カウントが(n — 1)になっていたら強制的にリセットをかけるようにします。リスト 4.16 に、同期式 5 進カウンタのコードを示しますのでリスト 4.15 と比較してください。

リスト 4.17 には、リセット機能の付いた 7 進カウンタのコードの一部(アーキテクチャ宣言 部)を示します。非同期リセットと同期リセットの記述の違いを確認してください。両者では、 process 文のセンシティビティリストと信号 RESET を判定するタイミングが異なります.

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity list16 is
   Port ( CLK : in std logic;
            Q : out std_logic_vector(2 downto 0));
end list15;
                                                    内部信号 WORK
                                                    の宣言
architecture Behavioral of list16 is
      signal WORK : std logic vector(2 downto 0) ;
begin
                                             ネガティブエッジで動作
process (CLK)
begin
    if(CLK'event and CLK='0') then
             if (WORK = "100") then
                                             (100)2になっていたらリセット
                   WORK <= "000";
             else
                   カウントアッフ
           end if;
      end if;
end process;
Q <= WORK ;
                                             出力Qへの代入処理
end Behavioral;
                     リスト 4.16 同期式 5 進力ウンタのコード
architecture Behavioral of list17a is
      signal WORK: std logic vector(2 downto 0);
begin
process (CLK, RESET)
begin
      if (RESET = '0') then
             WORK <= "000" ;
      elsif(CLK'event and CLK='0') then
             if (WORK = "110") then
                   WORK <= "000";
             else
                  WORK <= WORK + '1';
           end if;
      end if;
end process;
Q <= WORK ;
end Behavioral:
                    (a) 非同期リセットのアーキテクチャ宣言部
```

リスト 4.17 リセット付き 7 進力ウンタのコードの一部 (1)

```
architecture Behavioral of list17b is
       signal WORK : std_logic_vector(2 downto 0) ;
begin
process (CLK)
begin
       if (CLK'event and CLK='0') then
              if (RESET = '0') then
                    WORK <= "000" ;
              elsif(WORK = "110") then
                    WORK <= "000";
             else
                     WORK <= WORK + '1';
            end if;
       end if;
end process;
Q <= WORK ;
end Behavioral;
```

## (b) 同期リセットのアーキテクチャ宣言部

リスト 4.17 リセット付き 7 進力ウンタのコードの一部 (2)

## 例題 4 10

図 4.29 に示す同期式 10 進カウンタと同様の動作をする回路を VHDL で記述しなさい. ただし、端子 RESET は、同期リセットとすること.

## <動作表>

| CLK         | $Q_3$ | $Q_2$ | $Q_1$ | $Q_0$ |
|-------------|-------|-------|-------|-------|
| 0           | 0     | 0     | 0     | 0     |
| 1           | 0     | 0     | 0     | 1     |
| 2           | 0     | 0     | 1     | 0     |
| 3           | 0     | 0     | 1     | 1     |
| 4           | 0     | 1     | 0     | 0     |
| 5           | 0     | 1     | 0     | 1     |
| 2 3 4 5 6 7 | 0     | 1     | 1     | 0     |
| 7           | 0     | 1     | 1     | 1     |
| 8           | 1     | 0     | 0     | 0     |
| 8           | 1     | 0     | 0     | 1     |
| 10          | 0     | 0     | 0     | 0     |



図 4.29 同期式 10 進カウンタ

## 順客例

リスト 4.17 (b) を参考にコードを記述しましょう。10 進カウンタでは、4 個の FF が必要になります。リスト 4.18 に、同期式 10 進カウンタのコードを示します。

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity rei4_10 is
    Port ( CLK : in std_logic;
        RESET : in std_logic;
        Q : out std_logic_vector(3 downto 0));
end rei4_10;
```

```
architecture Behavioral of rei4 10 is
      signal WORK : std logic vector(3 downto 0) ;
begin
                                             CLKのポジティブ
process (CLK)
                                             エッジで動作
begin
      if (CLK'event and CLK='1') then
                                                   同期リセット
             if (RESET = '0') then
                 WORK <= "0000" ;
                                                    (1001)2になっていたら
             elsif(WORK = "1001") then
                                                    リセット
                 WORK <= "0000";
             else
                 WORK <= WORK + '1'; 	←
                                                    カウントアップ
        end if;
      end if;
end process;
                                                    出力Qへの代入処理
Q <= WORK ;
end Behavioral:
```

リスト 4.18 同期式 10 進力ウンタのコード

## ▶4.3.2 カウンタの応用

例題 4-10 で設計した 10 進カウンタを HDL トレーナーのクロック 4 MHz で動作させると高 速すぎて人の目では確認できません(111ページ参照).したがって、例題4-11で動作確認を 行いましょう.

## 例題 4-11

7セグメント LED を「0」~「9」まで順次表示することを繰り返す回路を VHDL で記述しなさ い. ただし、表示の切り替わり時間は約1秒とし、同期リセット端子 RESET を備えること。

## 解答例

図 4.30 に、HDLトレーナーを用いた 10 秒をカウント表示する回路の構成を示します。



図 4.30 10 秒をカウント表示する回路の構成

主要な回路は、分周回路、10進カウンタ、デコーダの三つです。これらはすべて、つぎの例題で学習しています

- ・分周回路 → 例題 4-8 (リスト 4.11)
- ・10 進カウンタ → 例題 4-10 (リスト 4.18)
- ・デコーダ → 例題 3-9 (リスト 3.25)

したがって、これらの回路を組合せれば 10 秒をカウント表示する回路を構成することができます。リスト 4.19 にコードの記述例を示しますので、表 4.11 に示すピン割り当てによって実習を行いましょう。リスト 4.19 を論理合成すると、「WARNING(:Xst:737 - Found 8-bit latch for signal <LED>.)」が出ますが、これはラッチ回路があることを示すメッセージなので問題ありません。

ここでは、実機(HDLトレーナー)による動作確認を行いましたが、シフトレジスタやカウンタなどの順序回路では、シミュレータソフトウェアを用いてシミュレーションを行うと動作確認が容易になります。シミュレーションについては、第6章で説明します。

```
library IEEE;
                                                        -- カウンタ回路
use IEEE.STD LOGIC 1164.ALL;
                                                        process (CE)
use IEEE.STD LOGIC ARITH.ALL;
                                                        begin
use IEEE.STD LOGIC UNSIGNED.ALL;
                                                                if (CE'event and CE='1') then
                                                                        if (RESET = '0') then
entity rei4 11 is
                                                                               WORK <= "0000" ;
  Port (CLK : in std_logic;
                                                                        elsif(WORK = "1001") then
       RESET : in std logic;
                                                                                WORK <= "0000";
       LED: out std logic vector(7 downto 0));
                                                                      else
end rei4 11;
                                                                                WORK <= WORK + '1' ;
                                                                   end if;
architecture Behavioral of rei4 11 is
       signal DD : std logic vector(21 downto 0);
                                                        end process;
       signal CE : std logic ;
       signal WORK : std logic vector(3 downto 0) ;
                                                        --デコーダ回路
begin
                                                        process (WORK)
                                                        begin
-- 分周回路
              22 ピット
                                                                case WORK is
process (CLK)
                                                                       when "0000" => LED <= "00000011";
hegin
                                                                       when "0001" => LED <= "10011111";
  if CLK'event and CLK='1' then
                                                                       when "0010" => LED <= "00100101";
      DD <= DD + '1';
                                                                       when "0011" => LED <= "00001101";
 end if;
                                                                       when "0100" => LED <= "10011001" :
end process;
                                                                       when "0101" => LED <= "01001001";
                                                                       when "0110" => LED <= "01000001";
process (DD)
                                                                       when "0111" => LED <= "00011011";
                                                                       when "1000" => LED <= "00000001";
 if DD = "111111111111111111111" then
                                                                       when "1001" => LED <= "00001001";
    CE <= '1';
                                                                       when others => null ;
                                                                end case;
    CE <= '0';
                                                        end process;
 end if;
                                                        end Behavioral;
end process;
```

リスト 4.19 10 秒をカウント表示する回路のコード

|    | 記号             | ピン番号 | 備考     |    |
|----|----------------|------|--------|----|
| 入力 | CLK            | 22   | CLK1   |    |
| 力  | RESET          | 34   | SW1    |    |
|    | LED(0)         | 50   |        | dp |
|    | LED(1)         | 61   |        | g  |
|    | LED(2)         | 60   |        | f  |
| 出力 | LED(3)         | 58   | LED4   | e  |
| 力  | LED(4)         | 56   | (LEDD) | d  |
|    | <i>LED</i> (5) | 55   |        | С  |
|    | <i>LED</i> (6) | 53   |        | b  |
|    | <i>LED</i> (7) | 52   |        | a  |

表 4.11 例題 4-11 のピン割り当て

## 例題 4・12

4 MHz のクロック信号をおよそ 4 kHz に分周する回路を VHDL で記述しなさい。そして、分周した信号を用いて HDL トレーナーのブザーを鳴らしなさい。

## 解答例

HDLトレーナーに搭載されているブザーは、連続した電圧を加えただけでは鳴らすことはできません。人が聞くことのできる周波数(およそ  $20~\text{Hz}\sim 20~\text{kHz}$ )の信号を加える必要があります。したがって、HDLトレーナーのセラロックが発振する 4~MHz の方形波を分周してからブザーに加えます。たとえば、周波数 4~kHz の方形波を発生するには、次式から 1/1000 に分周すればよいことがわかります。

$$4 \text{ MHz} \div x = 4 \text{ kHz}$$
  
 $x = (4 \times 10^6) \div (4 \times 10^3) = 1000$ 

 $2^{10} = 1024 = 1000$  と考えて、10 ビットで分周を行うことにします。これまでの記述法(リスト 4.11 など)によって、10 ビットの分周回路を記述するとリスト 4.20 に示すコード(process 文)になります。また、このコードで発生する出力信号 CE の波形を図 4.31 に示します。

```
process (CLK)
begin
    if CLK'event and CLK='1' then
        DD <= DD + '1';
    end if;
end process;

process (DD)
begin
    if DD = "1111111111" then
        CE <= '1';
else
        CE <= '0';
end if;
end process;</pre>
```

リスト 4.20 10 ビット分周回路のコード (その 1)



図 4.31 CEの波形 (リスト 4.20)

図 4.31 では、波形が 0 と 1 である時間が同じではありません、これまでの実習では、ポジティブエッジまたは ネガティブエッジを得るために分周していたので問題はありませんでした。しかし、この例題では、0と1が同じ 時間で変化する波形を得る必要があります。

リスト 4.21 に、 $0 \ge 1$  が同じ時間で変化する波形を得る分周回路のコード、図 4.32 に CE の波形を示します。 リスト 4.21 では、分周回路で 2<sup>10</sup>/2 のタイミングで、CE を切り替えていることに注目してください。

```
library IEEE;
                                                   4 kHz(0.25 ms)
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
                                         CE
entity rei4 12b is
    Port (CLK : in std logic;
                                                図 4.32 CEの液形 (リスト 4.21)
         BZ : out std logic);
end rei4 12b;
architecture Behavioral of rei4 12b is
      signal DD : std logic vector(9 downto 0);
       signal CE : std logic ;
begin
-- 分周回路
process (CLK)
begin
   if CLK'event and CLK='1' then
       DD <= DD + '1';
   end if;
end process;
                                        半分のカウント時間ごと
process (DD)
                                        に CE を切り替えている
begin
   if DD = "0111111111" then
     CE <= "1";
   elsif DD = "1111111111" then
     CE <= '0';
   end if;
end process;
BZ <= CE ;
end Behavioral:
```

## リスト 4.21 10 ビット分周回路のコード (その 2)

表 4.12 に示すピン割り当てによって実習を行いましょう。リスト 4.20 とリスト 4.21 のコードをダウンロードし て,ブザー音を比べてみましょう。また,ブザーに加える信号の周波数を変化させる実習も行うとよいでしょう。

記号 ピン番号 備考 CLK 22 CLK1 出力 BZ**BZOUT** 40

表 4.12 例題 4-12 のピン割り当て

▶ 演習問題 4

4.1 リスト 4.22 は、図 4.33 に示す JK-FF を VHDL で記述したコードである。①~⑩に適切な語句を埋めて コードを完成しなさい。ただし、JK-FFのRESET端子は、同期式リセットとする。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
                                                           CLK
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
                                                         RESET
entity syo4 1 is
                                                               ₩ 4.33 JK-FF
   Port ( J, K, CLK, RESET : in std logic;
          Q : out std logic);
end syo4 1;
architecture Behavioral of syo4_1 is
        signal INPUT : std_logic_vector(1 downto 0) ;
        signal WORK : std logic
begin
        INPUT \leftarrow (1);
        process (2)
        begin
                if (CLK'event and CLK = (3)) then
                          if (4 = 5) then
                             WORK <= '0';
                              else
                                   6 INPUT is
                                          when "01" => WORK <= '0';
                                          when "10" => WORK <= '1';
                                          when "11" => WORK <= (7);
                                          when (8) => null ;
                                   9 :
                         end if ;
                end if :
        end process ;
        0 <= 10;
end Behavioral;
```

## リスト 4.22 JK-FF のコード

- 4.2 同期式 4 進カウンタを VHDL で記述しなさい。ただし、クロック信号のポジティブエッジで動作し、同期 リセット端子(負論理)をもつこととする。
- 4.3 同期式9進カウンタを VHDL で記述しなさい. ただし、クロック信号のネガティブエッジで動作し、同期 リセット端子(負論理)をもつこととする。
- 4.4 例題 4-11 (122 ページ) で設計した 10 秒をカウント表示する回路において、カウンタ部をダウンカウンタ に変更して、7セグメント LED  $が0 \rightarrow 9 \rightarrow 8 \rightarrow \sim \rightarrow 1 \rightarrow 0$  と順次表示するコードを記述しなさい。ただし、 カウントダウンの記述には演算子「一」を使用すること.

# 第5章階層設計

これまでの実習では、分周回路、カウンタ回路、デコーダ回路などで構成されるディジタル回路を一つのコードとして記述してきました。つまり、一つのアーキテクチャ宣言部に各回路を記述していました。しかし、複雑なディジタル回路では、各部を分割して記述した方が構造を理解しやすくなり、また各種のトラブルを減少させることにもつながります。さらに、何度も使用する回路を独立したコードとして記述しておき、必要なときにそのコードを参照するようにすれば、何度も同じコードを記述する必要はなくなります。このように、



# 5.1 階層設計の基礎

は、図5.1を例にして階層設計について考えましょう。

複雑なディジタル回路の設計では、階層設計の考え方が不可欠になってきます。ここでは、階層設計の基本的な考え方と実際の記述パターンを理解しましょう。また、7セグメント LED を 2 桁使用する 100 秒カウンタや、電子サイコロなどの応用回路についての実習を行いましょう。

## ▶5.1.1 階層設計とは

全減算器 (FS) の動作記述については、例題 3-6 (85 ページ) で実習しました.一方、全減算器は、図 5.1 に示すように 2 個の半減算器 (HS) によって構成することもできます.ここで

0



図 5.1 半減算器 (HS) を用いた全減算器 (FS) の構成

図5.1では、同じ働きをする半減算器が2個使用されています。VHDLを用いてコードを記述する場合、各半減算器を個別に記述することもできますが、それでは効率がよいとはいえません。できれば、一箇所に記述した半減算器をうまく利用して全減算器の回路を構成したいものです。また、図5.1では、同じ機能(半減算器)を複数箇所で使用する場合を例に上げましたが、異なる機能である場合でも、各機能を個別に記述して、それらをまとめて全体を構成すると考え方が簡単になります。さらに、機能ごとに回路を考える方がエラーの発見が容易となりトラブルの減少にもつながります。複数の設計者が共同で大規模な回路を設計する場合にも、各機能を分担することが必要になります。このような記述を実現するのが階層設計の考え方です。

階層設計は、プログラミング言語におけるモジュール化やサブルーチンに似た考え方であると とらえることができます。しかし、サブルーチンでは同じメモリブロックにあるサブルーチンプ ログラムが繰り返し実行されますが、VHDLの階層設計で記述した機能は使用される回数分の 回路が実際に CPLD/FPGA 内に構成される点が異なります。

## ▶ 5.1.2 階層設計の方法

0

階層設計では、コンポーネント (component) 宣言とポートマップ (port map) 宣言を使用し た記述が基本となります。図 5.2 に。階層設計記述の流れを示します。



図 5.2 階層設計記述の流れ

初めに、各機能のコードを個別に記述しておきます。そして、階層設計用のコードには、コン ポーネント宣言によって別に記述した各機能の入出力端子に関する情報を記述し、ポートマップ 宣言によって各機能をつなぎ合わせる記述を行います。図 5.3 に、階層設計記述のイメージを示 します。



図 5.3 階層設計記述のイメージ

図 5.4 に階層設計用コードの記述パターン、図 5.5, 5.6 にコンポーネント宣言とポートマップ 官言の書式を示します。コンポーネント宣言とポートマップ宣言は、どちらもアーキテクチャ宣 **言内に記述します。コンポーネント宣言は信号宣言部、ポートマップ宣言は機能宣言部に記述し** ます (62ページ図 3.7 参照).

```
library IEEE;
       use IEEE.STD_LOGIC_1164.ALL;
                                         ―ライブラリ宣言
       use IEEE.STD_LOGIC_ARITH.ALL;
       use IEEE.STD LOGIC UNSIGNED.ALL;
       entity fs is
                                        ← エンティティ宣言
             Port (A: in std logic;
                  B: in std logic;
                  B I : in std logic;
                  D : out std logic;
                                                キテクチャ宣言
                  B 0 : out std logic);
       end fs;
       architecture Behavioral of fs is
        component hs
信号宣
                                           コンポーネント宣言
                Port (A : in std logic;
                   B : in std logic;
                   D : out std logic;
                   BO : out std logic);
        end component;
                                              - 内部信号の宣言
               signal HS1_D, HS1_BO, HS2_BO : std_logic ;
                                              ポートマップ宣言
        begin
         C1:hs
               port map (A =>, B =>B, D => HS1_D, BO => HS1_BO);
機能宣言
        C2:hs
            port map(A => HS1_D,B => B_I,D => D,B0 => HS2_B0);
        B_0 <= HS1_BO or HS2_BO; ← (代入処理)
        end Behavioral;
```

図 5.4 階層設計用コードの記述パターン



図 5.5 コンポーネント宣言の書式



図 5.6 ポートマップ管言の書式

コンポーネント宣言は、各機能を記述したコードのエンティティ宣言をコピーして利用すると よいでしょう、また、ポートマップ宣言では、代入の方向を間違えないようにしてください。

図 5.7 に示す全減算器を例にして階層設計の記述パターンを学習しましょう. 図 5.2 に示した流れに沿って作業を進めていきましょう. 初めは、各機能を個別に記述する作業、つまり半減算器の記述からです.



図 5.7 半減算器を用いた全減算器の構成

## ① 各機能の記述

半減算器を記述します。図 5.8 に半減算器各部の信号, リスト 5.1 にコードを示します (例題 3-5, 84 ページ参照).

library IEEE;



```
use IEEE.STD LOGIC_1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity hs is
 Port ( A : in std logic;
         B : in std logic;
         D : out std logic;
         BO : out std logic);
end hs:
architecture Behavioral of hs is
        signal X, Y:std logic ;
begin
        X \le A and (not B);
        Y \le B and (not A);
        D <= X or Y ;
        BO <= Y :
end Behavioral;
```

リスト 5.1 半減算器のコード

これまでの実習と同様に ISE WebPACK を起動します。そして、ツールバーの「File」  $\rightarrow$  「New Project」を選択し(図 5.9 参照)、たとえば「sample1」という名でプロジェクトを作成します。続いて、ツールバーの「Project」  $\rightarrow$  「New Source」を選択し(図 5.10 参照)、「VHDL Module」のファイル名をたとえば「hs」として新規コードを記述するウインドウを開きます。この際、入力はAとB,出力はDとBO,すべて「std\_logic 型」です。



図 5.10 「Project」→「New Source」を選択

リスト 5.1 に示したコードを入力したら、論理合成「Synthesize – XST」を実行してエラーのないことを確認します(図 5.11)。



図 5.11 半減算器の論理合成「Synthesize-XST」を実行

## ② コンポーネント宣言

続いて、階層設計用のコードを記述します。図 5.12 に、設計する全減算器各部の信号を示します。

ツールバーの「Project」  $\rightarrow$  「New Source」を選択し(図 5.13 参照),「VHDL Module」のファイル名をたとえば「fs」として新規コードを記述するウインドウを開きます(図 5.14 参照).この際,入力はA, B,  $B\_I$ , 出力はDと $B\_O$ , すべて「 $std\_logic$ 型」です.



図 5.12 全減算器各部の信号



図 5.13 「Project」→ 「New Source」を選択



図 5.14 「VHDL Module」のファイル名を「fs」とする

図 5.15 に示すように、「Sources in Project」ウインドウには、先ほど作成した「hs-behavioral (hs.vhd)」コードに加えて、「fs-behavioral (fs.vhd)」コードが追加されているはずです。 アーキテクチャ宣言内の信号宣言部に、リスト 5.2 に示すコンポーネント宣言を記述します(130ページ図 5.4 参照).



図 5.15 「fs-behavioral (fs.vhd)」コードが追加された

component hs

Port ( A : in std\_logic; B : in std\_logic; D : out std\_logic; BO : out std logic);

end component;

リスト 5.2 コンポーネント宣言

## ③ ポートマップ宣言

アーキテクチャ宣言内の信号宣言部に、signal 文を用いて内部信号を宣言します。

signal HS1\_D, HS1\_BO, HS2 BO : std logic ;

続いて、アーキテクチャ宣言内の信号宣言部に、リスト 5.3 に示すポートマップ宣言を記述します(130 ページ図 5.4 参照)。 コンポーネントとしては、半減算器 hs を 2 個使用しますので、記述するポートマップ宣言も二つ必要です。 ラベルは、component の頭文字 C を用いて、C1、C2 としました。ポートマップ宣言では、代入の方向によってコンポーネントと、代入先を区別します。 したがって、同じ記号を用いたポート名(たとえば、A, B, D)があってもかまいませんが、記述順序に注意してください。

```
C1:hs
port map(A => A, B => B, D => HS1_D, BO => HS1_BO);

C2:hs
port map(A => HS1_D, B => B_I, D => D, BO => HS2_BO);

リスト 5.3 ポートマップ宣言
```

アーキテクチャ宣言の機能宣言部に、全滅算器の出力  $B\_O$  を得るための OR 回路を記述します。

```
B O <= HS1 BO or HS2 BO;
```

階層設計用コードの記述が終われば、ツールバーの「File」  $\rightarrow$  「Save」(または保存ボタン)を選択してコードを保存します。半減算器のコード「hs-behavioral (fs.vhd)」は、全減算器のコード「fs-behavioral (fs.vhd)」(階層設計用コード)の下位のモジュールになりますので、タイトルが一段下がって表示されているはずです(図 5.16 参照)。



図 5.16 階層設計用のコード記述ウインドウ

リスト 5.4 に示したコードを入力したら、「Sources in Project」ウインドウで「fs-behavioral (fs.vhd)」が選択されていることを確認して、論理合成「Synthesize-XST」を実行します。この場合には、「WARNING:Xst:1355 - Unit hs is merged (low complexity)」という警告が出ますが、これはコンポーネント hs を取り込んだというメッセージですので問題ありません(図 5.16 参照).

リスト 5.4 全減算器の階層設計コード

論理合成が終了したら、「View RTL Schematic」を実行して、合成された回路をみてみましょう。図 5.17 に示すように、1 個の全滅算器が、2 個の半滅算器で構成されていることが確認できるはずです。



つぎに、表 5.1 に示すピン割り当てを行い、HDLトレーナーにファイル「fs.jed」をダウンロードして実習を行いましょう。 念のため、表 5.2 に全減算器の真理値表を示します。

| Dad. | 己号  | ピン番号 | 備考       |
|------|-----|------|----------|
| 入力   | A   | 34   | SW1      |
|      | В   | 35   | SW2      |
|      | B_I | 36   | SW3      |
| 出力   | D   | 74   | LED3 の g |
|      | B_O | 61   | LED4のg   |

表 5.1 全減算器のピン割り当て

| 表 5.2 宝刚昇奇の具理他衣 |   |            |   |     |
|-----------------|---|------------|---|-----|
| A               | В | <i>B_I</i> | D | B_O |
| 0               | 0 | 0          | 0 | 0   |
| 0               | 0 | 1          | 1 | 1   |
| 0               | 1 | 0          | 1 | 1   |
| 0               | 1 | 1          | 0 | 1   |
| 1               | 0 | 0          | 1 | 0   |
| 1               | 0 | 1          | 0 | 0   |
| 1               | 1 | 0          | 0 | 0   |
| 1               | 1 | 1          | 1 | 1   |

ポートマップ宣言の書式は図 5.6 (130 ページ) に示しましたが、リスト 5.5 に示す記述法もあ ります. この記述法では、コンポーネント宣言に記述したポート名 (A, B, D, BO) と同じ順 で、ポートマップ宣言に記述した代入先への代入処理が行われます。

```
library IEEE;
                  use IEEE.STD LOGIC 1164.ALL;
                  use IEEE.STD LOGIC ARITH.ALL;
                  use IEEE.STD LOGIC UNSIGNED.ALL;
                  entity fs is
                     Port ( A : in std_logic;
                             B : in std logic;
                             B I : in std logic;
                             D : out std logic;
                             B O : out std logic);
                  end fs;
                                                              コンポーネント宣言の記
                  architecture Behavioral of fs is
                                                              述順序に対応した代入処
                                                              理が行われる
                  component hs
                          Port ( A : in std logic;
A = > A
                                 B : in std logic;
B = > B
                                 D : out std logic;
D = > HS1 D
                                 BO : out std logic);
BO = > HS1_BO
                  end component;
                         signal HS1 D, HS1 BO, HS2 BO : std logic ;
A = > HS1_D
B = > B_I
                  begin
D = > D
                                                                 代入先のみ記述する
                  C1:hs
BO = > HS2 BO
                         port map(A , B, HS1_D, HS1_BO) ;
                 C2:hs
                         port map(HS1 D, B I, D, HS2 BO);
                  B O <= HS1 BO or HS2 BO ;
                  end Behavioral;
```

リスト 5.5 ポートマップ宣言の記述法

### 階層設計の実習

ゲートと FF が記述できるようになり、階層設計が理解できれば、VHDL を用いて多くのディ ジタル回路を設計することが可能になります。ここでは、階層設計の理解を深めるためにいくつ かの例題を実習しましょう。

#### ▶ 5.2.1 10 砂カウンタの設計

例題 4-11 (122 ページ) で実習した 10 秒カウンタ回路を、ここでは階層的に設計してみま しょう.

#### 例題 5-1

7セグメント LED を「0」~「9」まで順次表示することを繰り返す回路を階層的に設計しなさ い(図 5.18 参照). ただし、表示の切り替わり時間は約1秒とし、同期リセット端子 RESET を 備えること。



#### 解答例

分周回路, 10進カウンタ, デコーダを独立したコード (モジュール) として記述し, 階層設計用コードでまと めましょう. 各コードの名前は,階層設計用を「watch10」,分周回路を「divider22」,カウンタを「counter10」, デコーダを「decoder8」とします。これらのコードの階層構造を図 5.19 に示します。「watch10」が最上位に位置 し、その下位に三つのコードが並んだ形になります。



図 5.20 に、設計する回路の各部の信号を示します。



図 5.20 10 秒カウンタの各部の信号

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity watch10 is
    Port ( CLK : in std logic;
           RESET : in std logic;
           DOUT : out std logic vector(7 downto 0));
end watch10;
architecture Behavioral of watch10 is
component divider22
    Port (CLK : in std_logic;
         CEOUT : out std logic);
end component;
component counter10
    Port (CE : in std_logic;
         RESET : in std logic;
          CNT : out std_logic_vector(3 downto 0));
end component;
component decoder8
    Port (DIN : in std logic vector(3 downto 0);
         DOUT : out std logic vector(7 downto 0));
end component;
       signal CE TMP : std logic ;
       signal CNT_TMP : std_logic_vector(3 downto 0) ;
begin
C1:divider22
       port map(CLK => CLK, CEOUT => CE_TMP) ;
C2:counter10
       port map(CE => CE TMP, RESET => RESET, CNT => CNT TMP) ;
C3:decoder8
       port map(DIN => CNT_TMP, DOUT => DOUT) ;
end Behavioral;
```

リスト 5.6 10 秒カウンタ階層設計用 (watch10) のコード

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity divider22 is
   Port (CLK : in std logic;
         CEOUT : out std logic);
end divider22:
architecture Behavioral of divider22 is
        signal DD : std_logic_vector(21 downto 0) ;
process (CLK)
begin
   if CLK'event and CLK='1' then
       DD <= DD + '1';
   end if;
end process;
process (DD)
begin
   if DD = "111111111111111111111" then
      CEOUT <= '1';
   else
      CEOUT <= '0':
   end if:
end process;
end Behavioral;
              リスト 5.7 分周回路 (divider22)
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity counter10 is
   Port (CE : in std logic;
         RESET : in std_logic;
         CNT : out std_logic_vector(3 downto 0));
end counter10;
architecture Behavioral of counter10 is
        signal WORK : std_logic_vector(3 downto 0) ;
begin
process (CE)
begin
        if (CE'event and CE='1') then
                 if (RESET = '0') then
                          WORK <= "0000";
                 elsif(WORK = "1001") then
                          WORK <= "0000";
                 else
                       WORK <= WORK + '1';
       end if;
   end if;
end process;
CNT <= WORK ;
end Behavioral;
          リスト 5.8 カウンタ (counter10) のコード
```

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity decoder8 is
    Port (DIN : in std logic vector(3 downto 0);
          DOUT : out std logic vector(7 downto 0));
end decoder8;
architecture Behavioral of decoder8 is
begin
process (DIN)
begin
        case DIN is
               when "0000" => DOUT <= "00000011";
                when "0001" => DOUT <= "10011111";
                when "0010" => DOUT <= "00100101" ;
                when "0011" => DOUT <= "00001101";
                when "0100" => DOUT <= "10011001";
                when "0101" => DOUT <= "01001001";
               when "0110" => DOUT <= "01000001";
               when "0111" => DOUT <= "00011011";
               when "1000" => DOUT <= "00000001";
                when "1001" => DOUT <= "00001001";
                when others => null ;
        end case;
end process;
end Behavioral;
```

リスト 5.9 デコーダ (decorer8) のコード

リスト 5.6 に階層設計用のコード, リスト 5.7, 5.8, 5.9 に下位に位置する三つの回路のコードを示します。下位のコードは, 123 ページのリスト 4.19 を三つに分割したものと考えることができます。

まず、ツールバーの「Project」→「New Source」を選択して下位に位置する三つのコードをおのおの記述します。図 5.21 に、三つのコードを記述した後の「Sources in Project」 ウインドウを示します。

図 5.21 で各コードをクリックして選択した後、論理合成「Synthesize - XST」を実行します。デコーダ (decorder8) で、「WARNING: Xst: 737 - Found & bit latch for signal < DOUT >.」という警告が出るかもしれませんが、これはラッチ回路が見つかったという確認メッセージですので問題ありません。



図 5.21 「Sources in Project」ウインドウ

続いて、階層設計用コード(watch10)を記述すると、図 5.22 に示すように「Sources in Project」ウインドウに各コードの階層構造が表示されます。



図 5.22 各コードの階層構造

「Sources in Project」ウインドウで「watch10-behavional(watch10.vhd)」を選択した後、「Assign Package Pins」をダブルクリックして(図 5.23 参照)、表 5.3 に示すピン割り当てを行います。



図 5.23 「Assign Package Pins」をダブルクリックする

|    | 記号      | ピン番号 | 備者             | × 5 |
|----|---------|------|----------------|-----|
| 入力 | CLK     | 22   | CLK            | l   |
|    | RESET   | 34   | SW1            |     |
| 出力 | DOUT(0) | 50   |                | dp  |
|    | DOUT(1) | 61   |                | g   |
|    | DOUT(2) | 60   | LED4<br>(LEDD) | f   |
|    | DOUT(3) | 58   |                | е   |
|    | DOUT(4) | 56   |                | d   |
|    | DOUT(5) | 55   |                | С   |
|    | DOUT(6) | 53   |                | b   |
|    | DOUT(7) | 52   |                | a   |

表 5.3 例題 5-1 のピン割り当て

なお、47ページの説明では、ピン割り当ての前に「Implemantation Constructions File」を作成しました。しかし、このファイルの作成前に「Assign Package Pins」をダブルクリックするとファイル作成を自動的に作成する確認メッセージが現れます(図 5.24 参照).



図 5.24 「Implementation Constructions File」自動作成メッセージ

図 5.25 に、ピン割り当て用ファイル「watch10.ucf」を作成した後の「Sources in Project」ウインドウを示します。



図 5.25 「watch10.ucf」を作成した

ピン割り当てを終えたらば、HDLトレーナーに「watch10.jed」ファイルをダウンロードして動作実習を行いましょう。

#### ▶5.2.2 100 静カウンタの設計

例題 5-1 では、1 桁の 7 セグメント LED を使用した 10 秒カウンタを設計しました。ここでは、2 桁の 7 セグメント LED を使用した 100 秒カウンタを階層的に設計してみましょう。

#### 例題 5-2

2 桁の7 セグメント LED を [00]  $\sim$  [99] まで順次表示することを繰り返す回路を階層的に設計しなさい (図 5.26 参照). ただし、表示の切り替わり時間は約1 秒とし、同期リセット端子 **RESET** を備えること、



図 5.26 100 秒カウンタの構成

#### 解答例

分周回路とデコーダは、例題 5-1 で設計したコードを流用することができます。デコーダは、同じものが 2 個 必要ですが階層設計をすれば 1 度の記述で済みます。カウンタは、2 個の 7 セグメント LED 用の信号を出力するように設計する必要があります。各コード名は、階層設計用を「watch100」、分周回路を「divider22」、カウンタを「counter100」、デコーダを「decoder8」とします。図 5.27 に、100 秒カウンタの各部の信号を示します。



図 5.27 100 秒カウンタ各部の信号

リスト 5.10 に階層設計用コード, リスト 5.11 にカウンタのコードを示します. 分周回路 (divider22) はリスト 5.7, デコーダ (decoder8) はリスト 5.9 と同じです.

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD_LOGIC UNSIGNED.ALL;
entity watch100 is
   Port ( CLK : in std logic;
          RESET : in std logic;
           DOUT1 : out std logic_vector(7 downto 0) ;
          DOUT2 : out std_logic_vector(7 downto 0));
end watch100;
architecture Behavioral of watch100 is
                                                      分周回路のコンポーネント宣言
component divider22
   Port (CLK : in std logic;
                                                      カウンタのコンポーネント官言
         CEOUT : out std logic);
end component;
component counter100 -
   Port (CE : in std logic;
         RESET : in std logic;
         CNT1 : out std logic vector (3 downto 0) ;
         CNT2 : out std_logic_vector(3 downto 0));
end component;
```

```
デコーダのコンポーネント宣言
component decoder8 -
    Port (DIN : in std logic vector(3 downto 0);
      DOUT : out std_logic_vector(7 downto 0));
end component;
                                                     内部信号の官言
      signal CE TMP : std logic ;
      signal CNT1 TMP : std logic vector(3 downto 0) ;
      signal CNT2_TMP : std_logic_vector(3 downto 0) ;
begin
                                                               ポートマップ官言
C1:divider22
    port map(CLK => CLK, CEOUT => CE TMP) ;
C2:counter100
    port map(CE => CE_TMP, RESET => RESET, CNT1 => CNT1 TMP, CNT2 => CNT2 TMP) ;
C3:decoder8
    port map(DIN => CNT1_TMP, DOUT => DOUT1) ;
C4:decoder8
    port map(DIN => CNT2 TMP, DOUT => DOUT2);
end Behavioral;
              リスト 5.10 100 秒カウンタ階層設計用 (watch100) のコード
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD_LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity counter100 is
    Port (CE : in std_logic;
         RESET : in std logic;
         CNT1 : out std logic vector(3 downto 0) ;
         CNT2 : out std logic vector(3 downto 0));
end counter100;
architecture Behavioral of counter100 is
                                                          2桁目の7セグメント
       signal WORK1 : std logic_vector(3 downto 0);
                                                          LED 動作用信号 CE100
       signal WORK2 : std logic vector(3 downto 0) :
                                                          の宣言
       signal CE100 : std logic : -
begin
                                                          1桁目の7セグメント
process (CE) <
                                                          LED の動作
begin
       if (CE'event and CE='1') then
               if (RESET = '0') then
                       WORK1 <= "0000";
               elsif(WORK1 = "1001") then
                      WORK1 <= "0000" ;
               else
                       WORK1 <= WORK1 + '1';
       end if;
   end if;
end process;
                                                       2桁目の7セグメント LED 動
                                                       作用信号 CE100 の生成
process (WORK1)
begin
       if (WORK1 = "1001") then
             CE100 <= '1';
             CE100 <= '0';
       end if;
```

```
end process;
                                                         2 桁目の 7 セグメント
process(CE) ◀
                                                         LED の動作
begin
       if (CE'event and CE='1') then
             if (RESET = '0') then
                   WORK2 <= "0000";
             elsif (CE100='1') then
                    if(WORK2 = "1001") then
                         WORK2 <= "0000";
                    else
                         WORK2 <= WORK2 + '1';
                    end if ;
             end if;
      end if;
end process;
                                                          各 7 セグメント LED への
                                                         出力代入処理
CNT1 <= WORK1 ; 	←
CNT2 <= WORK2 :
end Behavioral ;
```

リスト 5.11 100 秒カウンタ (counter100) のコード

リスト 5.11 では、2 桁目の 7 セグメント LED を動作させる信号 CE100 を生成する process 文を記述しています。この process 文によって、1 桁目の 7 セグメント LED の表示が「9」のときに、CE100 は「1」に立ち上ります。2 桁目の 7 セグメント LED は、分周後のクロック CE に同期しながら CE100 の値によってカウントを進めます。

表 5.4 に、HDL トレーナーのピン割り当てを示します。 プッシュスイッチ SW1 を押すと同期リセットが働くことなどを確認してください。

|    | 記 号      | ピン番号 | 備              | ¥  |  |
|----|----------|------|----------------|----|--|
| 入力 | CLK      | 22   | CLK            | ζ1 |  |
| カ  | RESET    | 34   | SW1            |    |  |
|    | DOUT1(0) | 50   |                | dp |  |
|    | DOUT1(1) | 61   |                | g  |  |
|    | DOUT1(2) | 60   |                | f  |  |
|    | DOUT1(3) | 58   | LED4<br>(LEDD) | е  |  |
|    | DOUT1(4) | 56   |                | d  |  |
|    | DOUT1(5) | 55   |                | С  |  |
|    | DOUT1(6) | 53   |                | b  |  |
| 出力 | DOUT1(7) | 52   |                | a  |  |
| 力  | DOUT2(0) | 64   |                | dp |  |
|    | DOUT2(1) | 74   |                | g  |  |
|    | DOUT2(2) | 73   |                | f  |  |
|    | DOUT2(3) | 72   | LED3<br>(LEDC) | е  |  |
|    | DOUT2(4) | 71   |                | d  |  |
|    | DOUT2(5) | 70   |                | С  |  |
|    | DOUT2(6) | 68   |                | b  |  |
|    | DOUT2(7) | 67   |                | а  |  |

表 5.4 例題 5-2 のピン割り当て

#### ▶ 演習問題 5

5.1 図 5.28 は、2 個の半加算器を用いた全加算器の構成図である。この回路を VHDL によって階層設計したリスト 5.12 の①~⑮に適当な語句を入れてコードを完成させなさい。



図 5.28 半加算器による全加算器の構成

```
library IEEE;
                                            library IEEE;
use IEEE.STD LOGIC 1164.ALL;
                                            use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
                                            use IEEE.STD_LOGIC_ARITH.ALL;
                                            use IEEE.STD LOGIC UNSIGNED.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
                                            (1) (12) is
1 fa is
                                                Port ( A : in std logic;
    Port ( C_I : in std_logic;
          A : in std logic;
                                                       B : in std logic;
           B : in std logic;
                                                       S : out std logic;
           S : out std logic;
                                                       CO : out std logic);
                                            end 3;
           C O : out std logic);
end fa;
                                            architecture Behavioral of ha is
architecture Behavioral of fa is
                                            begin
(2) ha
                                            S <= A (A) B;
                                            CO <= A (15) B ;
   Port ( A : in std_logic;
           B : in std logic;
           S : out std logic;
                                            end Behavioral;
           CO : out std logic);
3;
   signal HA1 S : std logic ;
   signal HA1 CO : std logic ;
   signal 4 : std logic ;
begin
C1: (5)
port map (A => 6), B => B, 7 => HA1 S, CO => 8);
port map(A => 9, B => HA1 S, S => S, CO => HA2 CO);
C O <= HA1 CO 10 HA2 CO;
end Behavioral;
```

リスト 5.12 全加算器のコード

- 5.2 階層設計を行う利点を挙げなさい。
- 5.3 コンポーネント宣言とポートマップ宣言の書式について説明しなさい.

# 第6章 シミュレーションの基礎

VHDLで設計した回路を実機にダウンロードして動作させる前に、ソフトウェア上で回路の動作をシミュレーションすれば、トラブルを事前に発見することが可能になります。設計者の考えた理論どおりに回路が動作しているか否かを、タイムチャートをみながら視覚的に検討できます。また、回路に入力する各種の信号を実際に準備しなくても、シミュレータ上でいろいろな信号を作成して回路に与えることができます。シミュレーション用のソフトウェア(シミュレータ)としては、メンターグラフィック社の ModelSim が有名です。このシミュレータは、ザイリンクス社の ISE WebPACK に組み込んで使用できる無償版 MXE II Starter が配布されています。この章では、MXE II Starter を使用したシミュレーションを実習しましょう。



## 6.1 テストベンチ

シミュレーションを行うためには、テストベンチ(test bench)について理解しておくことが必要です。テストベンチとは、シミュレーションを行う回路に与える入力信号や、出力信号を観測するために記述するコードのことです。ここでは、テストベンチについての基礎を学びましょう。

#### ▶ 6.1.1 テストベンチとは

0

設計した回路が正しく動作するかどうかをシミュレーションでテストする場合には、適当な入力信号を与えて、回路の動作をチェックすることが必要です。たとえば、図 6.1 に示す半加算器において、図 6.2 のタイムチャートに示す入力信号 A、B を与えた場合に出力 S、C が正しく変化しているかどうかをチェックします。



図 6.1 半加算器の回路



図 6.2 半加算器のタイムチャート例

また、シフトレジスタやカウンタなどの同期式の順序回路では、適当なクロック信号を与えて、回路各部の信号の変化を観測します。このように、シミュレーションを行う場合に回路に与える入力信号を記述しておくのがテストベンチです(図 6.3 参照)。図 6.2 の例では、入力信号 A、Bをテストベンチに記述します。



図 6.3 テストベンチ

テストベンチに記述した信号は、シミュレーションソフトウェアによって、設計した回路に与えられます。しかし、テストベンチ自体は、ディジタル回路に変換されることはありません。たとえば、テストベンチに方形波を発生するクロック信号を記述したからといって、発振回路が合成されるわけではないのです。

#### ▶6.1.2 テストベンチの書き方

0

ここでは、図 6.4 に示す半減算器を例にしてテストベンチの書き方を学びましょう。半減算器 を VHDL で記述したコードをリスト 6.1 に示します。



```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;
use IEEE.STD_LOGIC_ARITH.ALL;
use IEEE.STD_LOGIC_UNSIGNED.ALL;

entity sample1 is
    Port ( A : in std_logic;
        B_I : in std_logic;
        D : out std_logic;
        B_O : out std_logic;;
end sample1;

architecture Behavioral of sample1 is
    signal X, Y:std_logic;

begin
    X <= A and (not B_I);
    Y <= B I and (not A);</pre>
```

リスト 6.1 半減算器のコード

D <= X or Y ; B O <= Y ;

end Behavioral;

リスト 6.2 に、この半減算器用テストベンチの例を示します。与える入力波形の記述方法は、後で詳しく説明します。ここでは、テストベンチ記述のパターンを理解してください。

リスト 6.2 は、設計した回路(半減算器)のコードと区別する意味でアルファベットの大文字を多く使用して記述しましたが、これまでと同様に小文字を中心とした記述でももちろんかまいません。テストベンチでは、コンポーネント宣言とポートマップ宣言を用いて、設計した回路(半減算器)のエンティティ宣言部とインタフェースを取ります。つまり、テストベンチは、設計した回路の上位階層に位置すると考えることができます。

このテストベンチによって、半減算器に与えられる信号 A、 $B\_I$  の波形パターンを図 6.5 に示します。

```
LIBRARY ieee;
                   USE ieee.std logic 1164.ALL;
                   USE ieee.numeric_std.ALL;
                   ENTITY sample1 tb vhd tb IS
                   END sample1 tb vhd tb;
                   ARCHITECTURE behavior OF sample1 tb vhd tb IS
コンポーネント宣言
                      COMPONENT sample1
                        PORT (
                            A : IN std logic;
                             B I : IN std logic;
                             D : OUT std logic;
                             B O : OUT std logic
                             );
半減算器の信号宣言.
                        END COMPONENT;
in や out などのモー
ドは不要
                       SIGNAL A : std logic;
                        SIGNAL B I : std logic;
                        SIGNAL D : std logic;
                        SIGNAL B_O : std_logic;
                 BEGIN
ポートマップ宣言
                     ➤ uut: sample1 PORT MAP(
                               A \Rightarrow A
                               B I => B I,
                               D => D,
                               B O => B O
                                                           このテストベンチ例では.
                       ) ;
                                                           process 文中に記述
                      tb : PROCESS
                     BEGIN
半減算器に与える入
                       ➤ A <= '0' ; B I <= '0' ;
力信号のパターンを
                          WAIT FOR 20 ns;
                                                A <= '1' ;
記述
                          WAIT FOR 10 ns;
                                                B I <= '1' ;
                                                 A <= '0';
                          WAIT FOR 10 ns;
                                                 B I <= '0' ;
                          WAIT FOR 10 ns;
                     END PROCESS;
```

END;

#### リスト 6.2 半減算器のテストペンチ例



図 6.5 半減算器に与えられる波形パターン

与える波形パターンの代表的な記述法は、以下の三つです。

#### ① 1/2 周期で状態が変化する繰り返し波形

-般的な方形波のクロック信号のように、'0'と'1'の時間が同じ周期で繰り返される波形で す(図 6.6 参照). 初期値の設定は、signal 文では省略して、アーキテクチャ宣言内の機能宣言 部で記述することもできます. ただし, signal 文で初期値を設定する場合には, 信号代入文 (<=) ではなく変数代入文(:=)を用いることに注意してください。



```
(b) 記述例
          signal CLK : std logic : = '0';
          CLK <= not CLK after 50 ns ;
```



図 6.6 1/2 周期で変化する繰り返し波形

#### ② 任意の時間で変化する繰り返し波形

任意の時間で変化する繰り返し波形を記述する方法です。 波形変化の指定は process 文中に記 述します (図 6.7 参照).

```
(a) 書式
           signal 信号名
                       : データ型 := 1
           process
           begin
              wait for | 時間 | ; 信号名 <= '値';
           end process;
```

(b) 記述例

```
signal CLK : std logic := '0'
process
    wait for 20ns ; CLK <= '1' ;
    wait for 30ns ; CLK <= '0' ;
end process;
```

(c) 波形パターン (ns) 50 70

図 6.7 任意の時間で変化する繰り返し波形

このときの process 文には、センシティビティリストが不要です。また、記述する時間は、初 期状態からの相対的な値を示します.初期値の設定は,signal 文では省略して process 文中で記 述することもできます (リスト 6.2 参照).

#### ③ 任意の時間で変化する有限時間の波形

任意の時間で変化する有限時間の波形を記述する方法です。記述する時間は、初期状態からの 絶対的な値を示します (図 6.8 参照).



図 6.8 任意の時間で変化する有限時間の波形

この他、VHDLの繰り返し制御用の「for 文」を使用して波形パターンを記述することも可能 です、また、ISE WebPACKには、別ファイルに記述した波形パターンを読み込んで使用する機 能(TEXTIO)や、図形として入力した波形パターンをテストベンチコードに変換する機能 (HDL Bencher) も備わっています.

## シミュレーション実習

論理シミュレーションの実習を行って、設計した回路の動作を検証しましょう。ここでは、 MXE II Starter がインストールされていることを前提にして実習を進めます。インストール法な どについては、第7章を参照してください。

#### ▶6.2.1 シミュレーションの手順

リスト 6.1 (151 ページ) で扱った半減算器のシミュレーションを例にして、実際の操作手順 を説明します.

#### ① 半減算器のコード記述

ここでは、プロジェクト名を「sample1」としました、記述を終えたら「Sysnthesize-XST」 を実行してエラーのないことを確認しておきましょう (図 6.9 参照).



図 6.9 半減算器の VHDL コードを記述

#### ② テストベンチ記述用ウインドウの準備

ツールバーの「Project」→「New Source」を選択し(図 6.10), 図 6.11 に示す「New Source」 ウインドウを表示します.このウインドウで,ファイル名をたとえば「tb」として,ウインドウ

左側で「VHDL Test Bench」を選択し「次へ」ボタンをクリックします。続いて現れるいくつかのウインドウは、そのまま進めていきます。

すると、テストベンチを記述するひな形の入ったウインドウが表示されます.



図 6.10 「Project」→ 「New Source」を選択



図 6.11 「VHDL Test Bench」を選択

#### ③ テストベンチの記述

リスト 6.3 に、自動的に作成されたテストベンチのひな形を示します(コメント文は削除してあります). リスト 6.3 では、PROCESS 文中に、リスト 6.4 に示す波形パターンを記述しましょう.

```
LIBRARY ieee;
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.ALL;
ENTITY samplel samplel tb vhd tb IS
END sample1 sample1 tb vhd tb;
ARCHITECTURE behavior OF sample1_sample1_tb_vhd_tb IS
      COMPONENT sample1
      PORT (
             A : IN std logic;
             B I : IN std logic;
             D : OUT std_logic;
             B O : OUT std logic
             );
      END COMPONENT;
      SIGNAL A: std logic;
      SIGNAL B I : std logic;
      SIGNAL D : std logic;
      SIGNAL B_O : std_logic;
BEGIN
  uut: sample1 PORT MAP(
           A => A,
           B I => B I,
           D => D,
           B 0 => B 0
    );
   tb : PROCESS
                                この部分に、波形パター
                                ンを記述する
   BEGIN
   END PROCESS;
```

END:

リスト 6.3 自動的に作成されたテストペンチのひな形

```
A <= '0' ; B_I <= '0' ;
WAIT FOR 20 ns ; A <= '1' ;
WAIT FOR 10 ns ; B_I <= '1' ;
WAIT FOR 10 ns ; A <= '0' ;
WAIT FOR 10 ns ;
                   B I <= '0' ;
```

リスト 6.4 波形パターン

#### ④ シミュレータの起動

「Module View」ウインドウでテストベンチファイルを選択した後,「Process View」ウインド ウの「ModelSim Simulator」の下位リスト部分にある「Simulator Behavioral Model」をダブルク リックして、MXE II Starter を起動します (図 6.12 参照).



図 6.12 MXE II Starter の起動

#### ⑤ シミュレータのリセット

シミュレータが起動すると,図 6.13 に示すように「メインウインドウ」,「シグナルウインドウ」,「ストラクチャウインドウ」,「ウェーブウインドウ」が表示されます.



図 6.13 シミュレータの起動画面

図 6.14 に示す「ウェーブウインドウ」の「リスタート」ボタンをクリックして現れるウイン ドウ (図 6.15 参照) で「Restart」をクリックして、「ウェーブウインドウ」をリセットします.



図 6.14 「ウェーブウインドウ」



図 6.15 リスタートウインドウ

#### ⑥ シミュレーションのスタート

「メインウインドウーから、シミュレーションを行う時間を入力してシミュレーションをス タートさせます. たとえば、100 ns のシミュレーションを行う場合には、「run 100 ns」と入力し ます (図 6.16 参照).



図 6.16 シミュレーションのスタート

#### ⑦ シミュレーション結果の表示

「ウェーブウインドウ」の「ズームフル」ボタンをクリックした後,「ズームイン」や「ズームアウト」ボタンをクリックして見やすい表示になるように調整します(図 6.17 参照).



図 6.17 半減算器のシミュレーション画面

#### ⑧ タイムチャートの検討

シミュレーションによって得られたタイムチャートを検討して、設計した回路(半減算器)の動作を検討しましょう。

MXE II Starter を終了する場合には、メインウインドウの右上の 🗶 をクリックします.

#### ▶ 6.2.2 順序回路のシミュレーション

0

シミュレーション実習として、同期式カウンタの動作を確認してみましょう.

#### 例題 6-1

同期式 10 進カウンタ(121 ページ例題 4-10)の動作をシミュレーションによって確認しなさい。ただし、同期リセットとすること。

#### 解签例

リスト 6.5 に 10 進カウンタのコードを示します.

```
library IEEE;
 use IEEE.STD LOGIC 1164.ALL;
 use IEEE.STD LOGIC ARITH.ALL;
 use IEEE.STD LOGIC UNSIGNED.ALL;
 entity rei4 10 is
     Port ( CLK : in std logic;
            RESET : in std logic;
            Q : out std_logic_vector(3 downto 0));
 end rei4 10;
 architecture Behavioral of rei4 10 is
        signal WORK : std logic vector(3 downto 0) ;
 begin
 process (CLK)
 begin
        if (CLK'event and CLK='1') then
               if (RESET = '0') then
                     WORK <= "0000";
               elsif(WORK = "1001") then
                     WORK <= "0000";
               else
                     WORK <= WORK + '1' ;
             end if;
        end if:
 end process;
 Q <= WORK ;
 end Behavioral;
```

リスト 6.5 10 進力ウンタのコード

このカウンタの入力信号は、クロック CLK とリセット RESET です。これらの波形パターンをたとえば、図 6.18 のように設定します。

つまり、CLK は 20 ns ごとに変化する 25 kHz の波形、RESET は 500 ns ごとに変化する 1 kHz の波形とします。 どちらも繰り返し波形であるとすると、153 ページの① 1/2 周期で状態が変化する繰り返し波形の書式で記述できます。 リスト 6.6 にテストベンチを示します。

メインウインドウで「run 2000 us」(us  $\mu$ s を意味します) と入力してシミュレーションを行った画面を図 6.19 に示します。 RESET が、'1' (時間 500  $\mu$ s) になるとカウンタが動作し,RESET が'0' (時間 1 ms) になる と CLK に同期してリセットがかかっている様子が確認できます。また,図 6.20 に示すように出力 Q の部分を右



```
USE ieee.std logic 1164.ALL;
USE ieee.numeric std.ALL;
ENTITY rei6_1_tb vhd tb IS
END rei6 1 tb vhd tb;
ARCHITECTURE behavior OF rei6 1 tb vhd tb IS
       COMPONENT rei6 1
       PORT (
              CLK : IN std logic;
              RESET : IN std logic;
              Q : OUT std logic vector (3 downto 0)
              );
       END COMPONENT;
       SIGNAL CLK : std logic:='0';
       SIGNAL RESET : std logic:='0';
       SIGNAL Q : std_logic_vector(3 downto 0);
BEGIN
       uut: rei6_1 PORT MAP(
              CLK => CLK,
              RESET => RESET.
              Q => Q
       );
       CLK <= not CLK after 20 us;
      RESET
              <= not RESET after 500 us;
```

END;

#### リスト 6.6 テストペンチ

クリックして、たとえば「Radix (基数)」を変更すれば、表示形式を変えることができます。

波形データは、「ウェーブウインドウ」のツールバーの「File」  $\rightarrow$  「Save Dataset」  $\rightarrow$  「sim」を選択して保存することができます。保存した波形データの読み込みは、「メインウインドウ」のツールバーの「File」  $\rightarrow$  「Open」  $\rightarrow$  「Dataset」で読み込むファイル名を指定します。その後、図 6.21 に示すように操作すれば「ウェーブウインドウ」が表示されます。



図 6.19 2000 µs (2 ms) までのシミュレーション結果の一部

10 進カウンタの動作が容易に見てとれる



図 6.20 出力 Q の表示形式の変更



図 6.21 保存した波形データの読み込み操作

# 第6章

#### ▶ 演習問題 6

- 6.1 つぎの①から⑤の記述で正しいものはどれか答えなさい。
  - ① VHDLでは、発振回路を記述して構成することができる。
  - ② テストベンチで記述したコードは、回路に合成されない。
  - ③ 論理シミュレーションでは、回路の遅延を考慮しない。
  - ④ 論理シミュレーションは、必ず行わなければならない。
  - ⑤ テストベンチは、テストする回路よりも下位の階層に位置する、
- **6.2** リスト 6.7, リスト 6.8 にテストベンチのコードの一部を示す。これにより、生成される各波形パターンを 図示しなさい。

```
      signal CLK: std_logic:= '1'
      CLK <= '1' , '0' after 20 us</td>

      CLK <= not CLK after 80 ns</td>
      '1' after 50 us

      '0' after 100 us

      UX > 6.7
```

**6.3** 図 6.22 に示す波形パターンは、80 ns までのパターンを繰り返すものである。この波形パターンを生成するテストベンチの一部であるリスト 6.9 の①から⑤に適当な語句を入れなさい。



signal RESET : std\_logic : = ① ;
②
begin
 wait for 20ns ; RESET <= ③ ;
 wait for 20ns ; RESET <= '0';
 wait for ④ ns ; RESET <= '1';
 wait for 30ns ; RESET <= '0';</pre>

リスト 6.9 テストペンチの一部

- 6.4 VHDLで記述した半加算器の回路をシミュレーションによって動作確認しなさい。
- 6.5 VHDLで記述した同期式5進カウンタの回路をシミュレーションによって動作確認しなさい。

# 第7音

# 第7章開発ツール

HDL を用いた回路設計に使用する開発ツールは、CPLD/FPGA メーカのホームページから無償でダウンロードして使用することができます。フリーとはいえ、多くは非常に高性能なソフトウェアです。この章では、ザイリンクス社の ISE WebPACK、およびアルテラ社の QuartusII Web Edition をダウンロードしてインストールする手順を説明します。また、メンターグラフィックス社のシミュレータ ModelSim の無償版についても同様の説明を行います。そして、HDL をマスターするのには不可欠な評価ボードの回路などについても理解しておきましょう。



### ザイリンクス社の開発ツール

ザイリンクス社の提供している開発ツールは、ISEとよばれています。ISEには、いくつかの 種類がありますが、フリーで入手可能なのは ISE WebPACK です。本書執筆時(2004.2)の ISE WebPACK の最新バージョンは、6.1i です、ここでは、例として Windows XP に ISE WebPACK 6.1i をインストール方法について説明します.

#### ▶ 7.1.1 ISE WebPACK の動作環境

有償版の ISE Foundation などは Windows 2000/XP に加えて Linux と SunSolaris にも対応して いますが、無償版の ISE WebPACK6.1i のサポートする OS は Windows 2000/XP のみです. Windows 2000 を使用する場合には、サービスパック 2 以上も必要となります。

パソコンは、Pentium クラス 500 MHz 以上の CPU が推奨されています、パソコンと評価ボー ドをパラレルインタフェースで接続するためには、パソコンにプリンタポートが備わっているこ とが必要です。また、パソコンに必要なメモリ容量は、ターゲットとなる CPLD/FPGA の機種 によって異なります。表 7.1 に、必要なパソコンメモリ容量の例を示します。たとえば、本書で 紹介した評価ボードには,CoolRunnerII が搭載されていますので,最低 128 MB の RAM と同量 の仮想メモリを用意しておく必要があります。

| ザイリンクスデバイス                                                                                                                                                                                                                                           | RAM    | 仮想メモリ  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|
| XC9500/XL/XV<br>CoolRunner, CoolRunner-II<br>Spartan-II XC2S15 から XC2S200 まで<br>Spartan-IIE XC2S50E から XC2S200E まで<br>Spartan-3 XC3S50 から XC3S200 まで<br>Virtex XCV50 から XCV150 まで<br>Virtex-E XCV50E から XCV200E まで<br>Virtex-II XC2V40 から XC2V250 まで | 128 MB | 128 MB |
| Spartan-IIE XC2S300E から XC2S600E まで<br>Spartan-3 XC3S400<br>Virtex XCV300 から XCV400 まで<br>Virtex-E XCV400E<br>Virtex-II XC2V500<br>Virtex-II Pro XC2VP2                                                                                              | 256 MB | 256 MB |

表 7.1 必要なパソコンメモリ容量の例

仮想メモリの設定は、つぎの手順で行います。

ナンス」) → 「システム」を選択して「システムのプロパティ」ウインドウを開きます. 開いた

ウインドウで、「詳細設定」タブ→パフォーマンスの「設定」→パフォーマンスオプションの 「詳細設定」タブと選択していくと、図7.1に示すパフォーマンスオプションのウインドウが開 きますので、そこで「変更」ボタンをクリックすれば設定が行えます。



図 7.1 仮想メモリの設定 (Windows XP)

パソコンには, Internet Explorer 5.0 以上, または Netscape Communicator 4.7 以上のブラウザ をインストールし、インターネットに接続しておきましょう。

ISE WebPACK 6.1i では、シミュレータ ModelSim の無償版である MEX II Starter を組み込ん で統合的な操作を行うことができます(158ページ参照)。

#### ▶ 7.1.2 ISE WebPACK の入手とインストール

ISE WebPACK は、ザイリンクス社のホームページからダウンロードして入手することができ ます (図 7.2). また, ザイリンクス社の代理店などから CD-ROM 版も配布されています (図 7.3).



図 7.2 ザイリンクス社のホームページ (http://www.xilinx.co.jp/)



図7.3 ISE WebPACK のCD-ROM版

ダウンロード版, CD-ROM 版のいずれを用いてインストールする場合においても, ザイリンクス社へのユーザ登録 (アカウントの作成) が必要になります.

#### ① ザイリンクス社のホームページからのダウンロードとインストール法

図 7.4 に、ISE WebPACK 6.1i をホームページからインストールする場合の流れを示します。



図 7.4 ホームページからインストールする流れ (Webinstall)

ここでは、新たにユーザ登録をする場合の流れをみていきましょう。図 7.2 に示したザイリンクス社のホームページから、「製品とサービス」ボタン→「デザインリソース」→「ISE WebPACK」と選択していき、図 7.5 に示すページを開きます。ここで、「ISE WebPACK ダウンロードの登録」ボタンをクリックすると図 7.6 に示す画面が現れます。

図 7.6 の画面で「アカウント作成」ボタンをクリックし、図 7.7 に示す「新しいアカウントの作成」画面で、氏名やユーザ ID、パスワードなどの情報を入力します。パスワードは半角の英数字 7 文字以上、ユーザ ID は小文字アルファベットと数字を使用して登録してください。ここで登録したユーザ ID とパスワードを使用すれば、以降はダウンロードのページへ直接ジャンプすることができます。

続いて「住所情報」画面でデータを入力した後、図 7.8 に示す画面で「職務内容などの概要」 を入力します、英語の部分は、開発分野や経験などに関する質問項目です。



図 7.5 ISE WebPACK ダウンロードのページ



図 7.6 アカウントの作成

入力後, つぎに進み図 7.9 に示すメッセージ画面が現れれば登録は終了です。まもなく登録した電子メールアドレス宛に, ザイリンクス社から 2 通のメールが送られてきます。

これらのメールには、ユーザ ID やパスワード、プロダクト ID などが記されています。また、登録したパスワードや電子メールアドレスなどの変更方法に関する情報も書かれていますので確認しておきましょう。



図 7.7 新しいアカウントの作成



図 7.8 職務内容などの概要

以上の操作で、ISE WebPACK 6.1i をインストールする資格が得られました。図 7.9 の [Download ISE WebPACK] 部分をクリックしてダウンロード画面に進みましょう。また、今後 は図7.4に示した画面からすぐにダウンロード画面に進むこともできます。



図 7.9 登録終了のメッセージ

ISE WebPACK 6.1i をホームページからインストールする場合には、シングルファイルダウンロード、および WebInstall とよばれる二種類の方法が利用できます。 ザイリンクス社では、後者を推奨していますので、図 7.10 の画面において「XILINX WebInstall」の部分をクリックします。



図 7.10 WebInstall を選択

すると、「ファイルのダウンロード」ウインドウが表示されますので、「保存」ボタンをクリックした後、適当な保存場所を指定してダウンロードを開始します。ダウンロードするのは、「WebPACK 61i installer.exe」という 1.4 MB 程度のインストーラファイルです。

「WebPACK\_61i\_installer.exe」のダウンロード終了後、図 7.11 に示すアイコンをダブルクリックすれば、ISE WebPACK 6.1i のインストール設定画面が現れます。



図 7.11 インストーラのアイコン

ソフトウェアライセンスの承諾やインストールディレクトリを指定する画面を進めていきます. 内容がよくわからなければ、そのまま次へ進めていけばよいでしょう. 図 7.12 に、各種の設定を終えたインストールの開始画面を示します.



図 7.12 インストールの開始画面

この画面で、「インストール」ボタンをクリックすると ISE WebPACK 6.1i のダウンロードとインストールが始まります(図 7.13)。 すべての機能をインストールするには、およそ 500 MB のハードディスク領域が必要になります。インストール終了までには、少々時間がかかることでしょう。

インストールが終了すると、Windows の再起動を求める画面が現れます。再起動を行ったディスクトップの画面には、図 7.14 に示すアイコンが表示されているはずです。



図 7.13 ISE WebPACK 6.1i インストール中



図 7.14 インストール後に表示されるアイコン

以上で、ISE WebPACK 6.1i のインストールは完了です。図 7.14 左側のアイコンをダブルクリックすると ISE WebPACK 6.1i が起動します(図 7.15)。



図 7.15 ISE WebPACK 6.1i を起動した画面

#### ② CD-ROM からのインストール法

図 7.16 に, ISE WebPACK 6.1i を CD-ROM からインストールする場合の流れを示します.



図 7.16 CD-ROM からインストールする流れ

CD-ROM からのインストールは、ホームページからのインストールに比べてダウンロードの時間が不要になります。また、ユーザ登録をしてユーザ ID とパスワードを取得しておくのに加えて、レジストレーション ID も取得する必要があります。

CD-ROM 版の ISE WebPACK 6.1i をインストールする実際の手順をみてみましょう.

始めに、ユーザ登録を行います。**CD-ROM を起動する**と、図 7.17 に示す画面が現れますので、「**Web** サイト」ボタンをクリックします。



図 7.17 CD-ROM の起動画面

すると、図 7.18 に示すようにザイリンクス社のホームページへジャンプします。ホームページ中の、「ログイン画面に進む」(Continue to login screen)の部分をクリックすると、図 7.19 に示す画面が現れます。



図 7.18 ザイリンクス社のホームページ



図 7.19 アカウントの作成(図 7.6 と同様)

図 7.19 は、図 7.6 と同じ「アカウントの作成」画面です。もしも英語表示になっている場合は、必要に応じて日本語表示に切り替えるとよいでしょう。ここからは、図 7.6 ~図 7.8 までと同様に氏名や住所、職務内容についての入力を行います。 やがて、図 7.20 に示す製品 ID を入力する画面が現れますので、CD-ROM の入っていた袋などに記載されている Product ID を入力します。



図 7.20 製品 ID の入力

この画面では、使用する OS (Windows) を選択することも忘れないでください。

登録が終了すると、電子メールでユーザ ID とパスワード、レジストレーション ID などが送信されてきますので確認しておきましょう.

図 7.17 へ戻り、「次へ」ボタンをクリックして先へ進み、ソフトウェアライセンスの承諾などを行うと、図 7.21 に示す画面が現れますので、取得したレジストレーション ID(Registration ID: 12 桁の英数字)を入力します。



図 7.21 レジストレーション ID の入力

続いて、インストールディレクトリを指定する画面などが現れますので、そのままつぎへ進めばインストールが開始されます。1枚目に引き続いて2枚目のCD-ROMで各種デバイスファイルのインストールを行います。

# アルテラ社の開発ツール

アルテラ社の提供している開発ツールには、Quartus II や MAX+PLUS II があります。ここで は、フリーで入手可能な Quartus II Web Edition を Windows XP パソコンにインストールする方 法について説明します. 本書執筆時点 (2004.2) での, Quartus II Web Edition の最新バージョ ンは、3.0です。

#### ▶ 7.2.1 Quartus II Web Edition の動作環境

Quartus II Web Edition 3.0 を動作させるためには、Pentium II (400 MHz 以上)、メインメモ リ 256 MB (512 MB 以上を推奨) を搭載したパソコンに, Windows NT 4.0 (サービスパック 3 以上), または Windows 2000/XP がインストールされていることが必要です. また. パソコン を評価ボードとパラレルケーブルで接続するためには、パソコンにプリンタポートが備わってい ることが必要です. パソコンには, Internet Explorer 5.0 以上のブラウザをインストールし, イ ンターネットに接続しておきましょう.

表 7.2 に、Quartus II Web Edition 3.0 のサポートするデバイスを示します。

| デバイス・ファミリ               | デバイス                   | デバイス・ファミリ              | デバイス  |
|-------------------------|------------------------|------------------------|-------|
| Cyclone <sup>TM</sup>   | 全デバイス                  | FLEX 10K*              | 全デバイス |
| Stratix <sup>TM</sup>   | EP1S10                 | FLEX 10KA              |       |
| APEX <sup>™</sup> II    | EP2A15                 | FLEX <sup>8</sup> 6000 | 全デバイス |
| Excalibur <sup>TM</sup> | EPXA1                  | MAX* 7000AE            | 全デバイス |
| APEX 20KE               | EP20K30E               | MAX 7000B              | 全デバイス |
|                         | EP20K60E               | MAX 3000A              | 全デバイス |
|                         | EP20K100E<br>EP20K160E | MAX 7000S              | 全デバイス |
| APEX 20KC               | EP20K200E              |                        |       |
| ACEX®                   | 全デバイス                  |                        |       |

表 7.2 Quartus II Web Edition 3.0 サポートデバイス

### ▶ 7.2.2 Quartus II Web Edition の入手とインストール

ここでは、アルテラ社のホームページから、Quartus II Web Edition 3.0 をダウンロードしてイ ンストールするまでの実際の手順を説明します。図7.22に、インストールの流れを示します。

図 7.23 に示すアルテラ社のホームページから、「製品情報 | → 「デザイン・ソフトウェア | →

「Quartus II Web Edition」と選択していくと、図 7.24 に示す画面が現れます。

図 7.24 の画面で、「Quartus II Web Edition ソフトウェアをダウンロード」部分をクリックし



図 7.22 Quartus II Web Edition 3.0 インストールの流れ



図 7.23 アルテラ社のホームページ (http://www.altera.co.jp/index.html)



図 7.24 Quartus II Web Edition 3.0 のページ

て、図 7.25 に示す画面に進みます。



図 7.25 ダウンロードのページ

図 7.25 で、「quartusii\_30\_web\_edition\_single.exe」の部分をクリックすると、図 7.26 のユーザ 登録画面が現れます。



図 7.26 ユーザ登録画面

新規登録の場合は、左側の入力欄に氏名や住所などを入力した後「Submit Request」ボタンをクリックして、「quartusii\_30\_web\_edition\_single.exe」ファイルのダウンロードを開始します。ファイルの大きさは、およそ137 MB です。

ダウンロードが終了すると、図7.27に示すインストール用のアイコンが現れます。



図 7.27 インストール用のアイコン

このアイコンをダブルクリックすると、いくつかのインストールの設定画面が現れますので、インストール先のディレクトリやフォルダなどの指定を進めていくと、インストールが開始されます(図7.28).



図 7.28 インストール実行中

インストールが終了すると、図 7.29 に示す Quartus II Web Edition 3.0 の起動アイコンが現れます。インストール後には、およそ 400 MB のハードディスク領域を使用します。



図 7.29 Quartus II Web Edition 3.0 のアイコン

#### ▶ 7.2.3 ライセンスの取得

0

これまでの手順で、Quartus II Web Edition 3.0 のインストールは終了しているのですが、このソフトウェアを使用するにあたっては、ライセンスの取得を行う必要があります。

ライセンスの取得を行う際には、パソコンの NIC (ネットワークインタフェースカード) のアドレスを入力する必要があります. NIC アドレスは、つぎの操作で知ることができます.

Windows XPの「スタート」ボタン→「すべてのプログラム」→「アクセサリ」→「コマンドプロンプト」を選択します(図 7.30).



図 7.30 コマンドプロンプトを起動



図 7.31 NIC アドレスを調べる

起動したコマンドプロンプトの画面に、「ipconfig/all」と入力し、リターンキーを押すと、パソコンのネットワークに関する各種情報が表示されます(図 7.31)。表示画面を見て、2 桁×6 個の NIC アドレスをメモしておきましょう。図 7.31 では、「ernet NIC Physical Address」として表示されています。番号をメモしたら、ウインドウ右上の ズ ボタンをクリックして、コマンドプロンプトウインドウを閉じておきましょう。

つぎに、ライセンスを取得する手順について説明します.

図 7.32 に示す,アルテラ社のダウンロードのページ(図 7.25 と同じ)において,「Get a license file」の部分をクリックします.



図 7.32 ダウンロードのページ(図 7.25 と同じ)

すると、図 7.33 に示す画面が現れますので、先ほど調べた NIC アドレスの番号を入力して [Continue] ボタンをクリックします。

続いて、図 7.34 に示す入力画面が現れますので、電子メールアドレスや氏名、住所などすべての項目に答えて「Continue」ボタンをクリックします。

図 7.35 に示す画面でも、「Continue」ボタンをクリックして先に進みます。



図 7.33 NIC アドレス番号の入力



図 7.34 ライセンス情報の入力



図 7.35 先へ進む「Continue」ポタンをクリック

図 7.36 に示す。使用者に関する質問画面に答えて、ページの終わりにある「Finish」ボタンを クリックすれば、ライセンス取得の手続きは終了です。



図 7.36 使用者に関する質問画面

図 7.34 で入力した電子メールアドレス宛に、ライセンス設定に必要なデータが送信されてき ます、送られてきた電子メールに添付されている拡張子「dat | のライセンスファイルは、 Quartus II Web Edition 3.0 をインストールしたフォルダ, たとえば、「c:\u00e4guartus | フォルダにコ ピーしておきます.

#### ▶ 7.2.4 ライセンスの設定

0

つぎに、インストールした Quartus II Web Edition 3.0 に取得したライセンスの設定を行いま す. Quartus II Web Edition 3.0 のアイコン(図 7.29)をダブルクリックして起動します. 起動は、 と選択して行うこともできます。

初めて、Quartus II Web Edition 3.0 を起動する際には、ライセンスの設定が行われていないこ とを警告するウインドウが表示されます(図 7.37), 図 7.37 の画面で、「Specify valid lisence file」 欄にチェックを入れて「OK」ボタンをクリックします.



図 7.37 ライセンスの設定を警告するウインドウ

続いて、図 7.38 に示すライセンスの設定画面が現れますので、先ほどアルテラ社より送信されてきた拡張子「dat」のファイルを指定します。たとえば、「c:\unitage quartus」フォルダ内のライセンスファイルを指定します。



図 7.38 ライセンスファイルの指定

ライセンスファイルの指定をして「OK」ボタンをクリックすれば、Quartus II Web Edition 3.0 のライセンスの設定は終了です。

#### ▶7.2.5 パラレルボート用ドライバの設定

これまでの操作で、Quartus II Web Edition 3.0 のインストールとライセンスの設定は終了しました。最後に仕上げとして、設計した回路のデータを評価ボードに転送するためのパラレルポート用ドライバを設定しておきましょう。

Quartus II Web Edition 3.0 を起動して、図 7.39 に示すように、「Tools」→「Programmer」を選択し、図 7.40 に示すウインドウを表示させます.



図 7.39 「Tools」→「Programmer」を選択



図 7.40 転送用ウインドウ

「Hardware」ボタンをクリックして表示される「Hardware Setup」ウインドウにおいて、「Add Hardware」ボタンをクリックします(図 7.41).

図 7.42 に示すウインドウで、「ByteBlasterMV or ByteBlasterII」、および「LPT1」を選択して [OK | ボタンをクリックします。

「Hardware」メニューの中に表示される「ByteBlasterMV」を選択して、「Select Hardware」ボタンと「Close」ボタンをクリックします(図 7.43).



図 7.41 「Hardware Setup」ウインドウ

| Hardware type: | ByteBlaster MV | or ByteBlaster II | * |
|----------------|----------------|-------------------|---|
| Port:          | LPTI           |                   | * |
| Baud rate      |                |                   | - |

図 7.42 「Add Hardware」 ウインドウ



図 7.43 「ByteBlasterVM」を選択

以上で設定は終了です. Quartus II Web Edition 3.0 を用いて設計した回路データをパラレル ポート (プリンタポート) 経由で評価ボードに転送することが可能になりました.

# 7.3

## シミュレータの入手とインストール

メンターグラフィックス社のシミュレータソフトウェア ModelSim には、無償版があります。 ここでは、ザイリンクス社の ISE WebPACK 6.1i に組み込んで使用できる無償版の MXE II Starter の入手とインストール手順を説明します。

#### ト7.3.1 MXE II Starter の入手とインストール

0

ここでは、MXE II Starter をザイリンクス社のホームページからダウンロードして、Windows XP パソコンにインストールするまでの実際の手順を説明します。図 7.44 に、インストールの流れを示します。

ダウンロード インストール ライセンスの取得 ライセンスの設定



図 7.44 MXE II Starter インストールの流れ

図 7.2 に示したザイリンクス社のホームページから,「製品とサービス」ボタン→「デザインリソース」→「ISE WebPACK」と選択していき,図 7.45 に示すページを開きます。



図 7.45 「ISE WebPACK をダウンロード」ポタンをクリック

すでにユーザ登録を済ませている方は、ここで、「ISE WebPACK をダウンロード」ボタンをクリックした後、ユーザ ID とパスワードを入力します。

続いて表示される画面の終わり方にある「完全な MXE シミュレータ」の部分をクリックします (図 7.46).



図 7.46 「完全な MXE シミュレータ」の部分をクリック

適当な保存先フォルダなどを指定すると、インストーラファイル「MXE\_5.7c\_Full\_installer.exe」のダウンロードが始まります。ダウンロードするファイルの大きさは、およそ 67 MB です。インストールが終了すると、図 7.47 に示すインストーラのアイコンが現れますのでダブルクリックして起動します。



図 7.47 ModelSim インストーラのアイコン

図 7.48 に示す確認用ウインドウの「OK」ボタンをクリックします。



図 7.48 インストール確認用ウインドウ

図 7.49 に示すウインドウで、「MXE II Starter – Limited Version of MXE II (Free」をチェックして「Next」ボタンをクリックします。



図 7.49 「MXE || Starter」を指定

引き続いて、ライセンスの同意やインストール先フォルダの設定ウインドウなどが現れますので、「Next」ボタンなどをクリックして進んでいきます。

図 7.50 に示すウインドウでは、使用する HDL の種類を設定します。 MXE II Starter では、インストール時に HDL を指定しなければなりません。ここでは、「Full VHDL」を指定して「Next」ボタンをクリックします。



図 7.50 使用する HDL を指定

続いて、いくつかの確認ウインドウが表示されますので、メッセージを確認して先へ進みましょう。図 7.51 に示すウインドウの「Finish」ボタンをクリックすれば、インストールは終了で

す。インストール後には、およそ 180 MB のハードディスク領域を必要とします。



図 7.51 インストールの最終ウインドウ

ディスクトップにアイコン作成を指定していれば、図 7.52 に示すショートカット用アイコンが表示されているはずです。



図 7.52 MXE II Starter のアイコン

#### ▶ 7.3.2 ライセンスの取得

MXE II Starter を使用する場合には、ライセンスを取得しておく必要があります。ここでは、インターネットを利用してライセンスを取得する手順を説明します。手続きの際には、使用するパソコンのハードウェア情報が自動的に送信されますので、MXE II Starter をインストールしたパソコンを使用して操作を行ってください。

これまでの操作で、MXE II Starter のインストールを終了すれば、図 7.51 に示したウインドウに続いて、図 7.53 に示すウインドウが表示されます。

すでに、ザイリンクス社へユーザ登録を済ませている方は、「Continue」の部分をクリックした後、ユーザ ID とパスワードを入力して先へ進みます。

図 7.54 に示すユーザ情報ウインドウが表示されたら、内容を確認して「Submit」ボタンをクリックします。

そして、続いて表示される確認用ウインドウに答えれば、登録した電子メールアドレス宛にラ イセンス情報が送信されます。



図 7.53 ライセンスの取得ウインドウ



図 7.54 ユーザ情報ウインドウ

### ▶ 7.3.3 ライセンスの設定

ライセンスの取得によって送られてきた電子メールには、拡張子「dat」のライセンスファイルが添付されています。ここでは、このライセンスファイルを用いてライセンスの設定を行う手順を説明します。ライセンスファイルは、設定によって MXE II Starter のフォルダにコピーされますので、とりあえずはディスクトップ上においておきます (図 7.55).



図 7.55 送信されてきたライセンスファイル

Windows XP の「スタート」ボタン→「すべてのプログラム」→「ModelSim XE II 5.7c」→ 「Licensing Wizard」を選択してライセンスウィザードを起動します(図 7.56).



図 7.56 ライセンスウィザードの起動

図 7.57 に示すウインドウが表示されますので、「Continue」ボタンをクリックします。



図 7.57 ライセンスウィザードの起動画面

図 7.58 に示すウインドウで、ライセンスファイル(図 7.55)の場所を指定します。この際、ディレクトリ名に全角文字を使用するとうまくいかない場合もあるようです。エラーメッセージの出る場合には、たとえば「C:Y」などにライセンスファイルをおいておけばよいでしょう。



図 7.58 ライセンスファイルの場所を指定

続いていくつかのメッセージウインドウ(図 7.59 など)が表示されますので、内容を確認して先へ進めばライセンスの設定は終了します。



図 7.59 メッセージウインドウ

設定終了後は、ディスクトップ上においたライセンスファイルや MXE II Starter インストーラファイル (図 7.60) を削除しておきましょう。



図 7.60 インストーラとライセンスファイル

以上で、MXE II Starter のインストールとライセンスの設定は終了です。

# 評価ボードの概要

本書では、ソリトンウェーブ社の評価ボード「HDLトレーナー」を例にして実習の手順を説 明しています、「HDLトレーナー」は、低価格な評価ボードですが、ザイリンクス社の CoolRunnerII (XC2C256) を搭載しており、実習には十分な性能をもった製品です、ここでは、 「HDLトレーナー」の概要について理解しましょう。

異なる評価ボードを使用する場合でも、スイッチや LED などの入出力装置と CPLD のピン割 り当てなどを考慮すれば、ほぼ同様の実習を行えることでしょう。

#### ▶ 7.4.1 HDLトレーナーの概要

0

図 7.61 に、HDLトレーナー (HDL-10) 一式の外観を示します。



図 7.61 HDL トレーナー一式の外観

HDL トレーナーには、つぎに示すものが含まれています。

- ・HDLトレーナー本体基板
- · AC アダプタ
- ・取り扱い説明書
- ・ザイリンクス社 ISE WebPACK インストール用 CD-ROM
- ・サンプルプログラムディスク
- ・ネジ4本

付属しているネジを本体基板のパラレルコネクタ (D-SUB コネクタ) に付いているナットと 交換すると、本体基板をパソコンのブリンタポートへ直接接続できるようになります (図 7.62). もちろん、D-SUB 25 ピンの延長ケーブル (オスーメス) を別途用意すれば、パソコンの前面に 本体基板をおいて実習を行うことも可能です (図 7.63).



図 7.62 パソコンに直接接続した例



図 7.63 延長ケーブルで接続した例

HDLトレーナーの特徴を以下にまとめます.

- ・実習には十分な 256 マクロセルの CPLD を搭載
- ・入力装置として、プッシュスイッチ5個、16進ディップスイッチ1個を搭載
- ・出力装置として、7セグメント LED4 個、ブザー1 個を搭載
- · JTAG インタフェース搭載
- ・パラレルコネクタ、シリアル通信用コネクタ各1個を搭載
- ・簡易型 A-D, D-A コンバータ搭載
- ・拡張用入出力端子を搭載

- · 保証期間1年間
- ・このクラスでは、群を抜く低価格(キャンペーン価格 9800 円)

図 7.64 に、本体基板の各部を示します。



図 7.64 HDL トレーナーの各部

HDLトレーナーに搭載されている CPLD のピンは、表 7.3 のように割り付けられています.

| No. | 接続先     | I/O   | No. | 接続先     | I/O   | No. | 接続先     | 1/0 | No. | 接続先     | I/O |
|-----|---------|-------|-----|---------|-------|-----|---------|-----|-----|---------|-----|
| 1   | DEB0    | INOUT | 26  | VCC1.8V | ., 0  | 51  | VCC3.3V | "0  | 76  | LEDB7   | OUT |
| 2   | DEB1    | INOUT | 27  | EXT     | OUT   | 52  |         | OUT | 77  | LEDB6   | OUT |
| 3   | DEB2    | INOUT | 28  | SPKOUT  | OUT   | 53  | LEDD5   | OUT | 78  | LEDB5   | OUT |
| 4   | DEB3    | INOUT | 29  | HEXSW3  | IN    | 54  | NC      |     | 79  | LEDB4   | OUT |
| 5   | VAUX    | IN    | 30  | HEXSW2  | IN    | 55  | LEDD4   | OUT | 80  | LEDB3   | OUT |
| 6   | DEB4    | INOUT | 31  | GND     |       | 56  | LEDD3   | OUT | 81  | LEDB2   | OUT |
| 7   | DEB5    | INOUT | 32  | HEXSW1  | IN    | 57  | VCC1.8V |     | 82  | LEDB1   | OUT |
| 8   | DEB6    | INOUT | 33  | HEXSW0  | IN    | 58  | LEDD2   | OUT | 83  | TDO     | OUT |
| 9   | DEB7    | INOUT | 34  | SW1     | IN    | 59  | NC      | -   | 84  | GND     |     |
| 10  | DEB8    | INOUT | 35  | SW2     | IN    | 60  | LEDD1   | OUT | 85  | LEDB0   | OUT |
| 11  | DEB9    | INOUT | 36  | SW3     | IN    | 61  | LEDD0   | OUT | 86  | LEDA7   | OUT |
| 12  | DEB10   | INOUT | 37  | SW4     | IN    | 62  | GND     |     | 87  | LEDA6   | OUT |
| 13  | DEB11   | INOUT | 38  | VCC3.3V |       | 63  | NC      |     | 88  | VCC3.3V |     |
| 14  | DEB12   | INOUT | 39  | AIN     | INOUT | 64  | LEDC7   | OUT | 89  | LEDA5   | OUT |
| 15  | DEB13   | INOUT | 40  | BZOUT   | OUT   | 65  | NC      |     | 90  | LEDA4   | OUT |
| 16  | DEB14   | INOUT | 41  | IRXD    | IN    | 66  | NC      |     | 91  | LEDA3   | OUT |
| 17  | DEB15   | INOUT | 42  | ITXD    | OUT   | 67  | LEDC6   | OUT | 92  | LEDA2   | OUT |
| 18  | NC      |       | 43  | ICTS    | OUT   | 68  | LEDC5   | OUT | 93  | NC      |     |
| 19  | NC      |       | 44  | NC      |       | 69  | GND     |     | 94  | LEDA1   | OUT |
| 20  | VCC3.3V |       | 45  | TDI     | IN    | 70  | LEDC4   | OUT | 95  | NC      |     |
| 21  | GND     |       | 46  | NC      |       | 71  | LEDC3   | OUT | 96  | NC      |     |
| 22  | CLK1    | IN    | 47  | TMS     | IN    | 72  | LEDC2   | OUT | 97  | LEDA0   | OUT |
| 23  | CLK2    | INOUT | 48  | TCK     | IN    | 73  | LEDC1   | OUT | 98  | VCC3.3V |     |
| 24  | CLK2    | INOUT | 49  | IRTS    | IN    | 74  | LEDC0   | OUT | 99  | nRESET  | IN  |
| 25  | GND     |       | 50  | LEDD7   | OUT   | 75  | GND     |     | 100 | GND     |     |

※ SW1 ~ 4, nRESET, LEDA ~ LEDD は負論理の信号となっています.

図 7.65 (a) (b) に, HDLトレーナーの全回路図を示します.





図 7.65(a) HDL トレーナーの全回路図



図 7.65(b) HDL トレーナーの全回路図

#### ▶7.4.2 HDLトレーナー拡張キットの構成

HDLトレーナーには、別売で拡張キット (2004.2 現在の販売価格は 2500 円) が用意されています。この拡張キットを利用すれば、幅広く各種の実習を行うことができます。図 7.66 に、拡張キット一式の外観を示します。



図 7.66 HDL トレーナー拡張キット一式の外観

HDLトレーナー拡張キットには、つぎのものが含まれています。

- ・外部スピーカ ・ボリューム ・ロータリエンコーダ
- ・サーミスタ · CDS セル · 取り扱い説明書
- ・サンプルプログラム CD-ROM (HDL トレーナーに付属しているものと同じ内容)

#### ▶ 7.4.3 HDLトレーナーの入手方法

a

HDLトレーナーと HDLトレーナー拡張キットは、ソリトンウェーブ社のホームページから通信販売による購入申し込みを行うことができます。また、HDLトレーナーの PDF 説明書は、ホームページからダウンロードすることも可能です。

・株式会社ソリトンウェーブ

東京都千代田区神田松永町 17-15 大野ビル 4F

TEL: 03-5256-0955

電子メール info@solitonwave.co.jp

ホームページ URL http://www.solitonwave.co.jp/index.html

このホームページには、HDLトレーナーに関するフォーラムも開設されています。

第7音

# 付録 Verilog-HDL について

Verilog-HDLは、VHDLより8年遅い1995年にIEEEによって標準化されたハードウェア記述言語ですが、VHDLと同様、多くのユーザに支持されています。どちらの言語を使用した場合でも、開発の流れは同じです。ここでは、VHDLと比較したVerilog-HDLの概要についてまとめておきます。

#### ▶ 付.1 Verilog-HDL の書き方

0

例として、2 入力 AND 回路を取り上げます。VHDL によるコードをリスト付 1、Verilog-HDL によるコードをリスト付 2 に示します。

```
library IEEE;
                                                         ライブラリ宣言
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity samplel is <
                                                         エンティティ宣言
   Port ( A : in std logic;
         B : in std logic;
          F : out std logic);
end sample1;
                                                        アーキテクチャ宣言
architecture Behavioral of samplel is
    F \le A and B;
end Behavioral;
                        リスト付1 VHDLのコード例
                                                    モジュール宣言
module sample2(A,B,F);
 input A;
 input B;
                     ポート宣言、ネット宣言、レジスタ宣言
 output F;
      assign F = A & B ;
                                   構造・動作記述部
endmodule
```

リスト付2 Verilog-HDL のコード例

VHDLはライブラリ宣言、エンティティ宣言、アーキテクチャ宣言から構成されますが、 Verilog-HDL の基本的なコードはモジュール宣言、ポート宣言、構造・動作記述部から構成され ます. つぎに、Verilog-HDLの各部について簡単に説明します.

① モジュール宣言: 設計する回路名とポートリストを記述します.

module 回路名 (ポートリスト):

② ポート宣言:入力と出力の宣言を記述します。

input 入力ポート名: output 出力ポート名 ;

③ 構造・動作記述部:設計する回路の構造や動作を記述します. assign 文は, 代入処理を行 う文です.

assign | 代入先 | = | 代入元 | ;

Verilog-HDL を使用する場合には、VHDL と異なる以下の項目について注意しましょう.

- ① 大文字と小文字を区別します。
- (2) 異なるビット幅の信号でも代入処理が可能です(右詰で代入処理されます).
- ③ 比較演算子の等しいには「==」を使用するなど、多くの演算子が VHDL と異なります。

#### ▶ 付.2 Verilog-HDLの文法

付表1に、VHDLと Verilog-HDLの主な文法を比較した一覧を示します。

付表 1 VHDLと Verilog-HDLの文法比較表

| 項目     | VHDL                                                                   | Verilog-HDL                                  |  |  |
|--------|------------------------------------------------------------------------|----------------------------------------------|--|--|
| コメント   | 1行のコメント                                                                | // 1行のコメント<br>/* */ 複数行のコメント                 |  |  |
| 文字     | 大文字と小文字を区別しない<br>(ただし ' ', " " 内では区別する)                                | 大文字と小文字を区別する                                 |  |  |
| データ型   | bit, std_logic,<br>std_logic_vector                                    | bit, integer<br>character                    |  |  |
| 定数     | '0', '1',<br>"001011111"                                               | 1' b0, 1' b1<br>8' h2f                       |  |  |
| ファイル指定 | libray IEEE;<br>use ファイル名;                                             | include " ファイル名 "                            |  |  |
| 入出力宣言  | ポート名]: モード型 データ型; A:in std_logic; B:out std_logic_vector (3 dounto 0); | モード型   ポート名 ;<br>input A;<br>output [3:0] B; |  |  |

```
項目
                     VHDL
                                                        Verilog-HDL
内部信号宣言
      signal 信号名: データ型;
                                           wire 信号名;
      signal A: std_logic;
                                            wire A;
      signal B: std_logic_vector (3 dounto 0);
                                            wire [3:0] B;
      代入先 <= 代入元;
                                           assign 代入先 = 代入元 ;
信号代入
            (:=) 変数代入
                                                      (<=) コンカレントな
                                                      (ノンブロッキング) 代入
      process ( )
                                            always @ ( )
順次処理文
      begin
                                            begin
      end process;
                                            end
 トリガ
      CLK' event and CLK ='1'
                                            posedge CLK
      CLK' event and CLK = '0'
                                            negedge CLK
      if (条件式) then
                                            if (条件式)
          処理1;
                                                処理1;
      else
                                           else
          処理2:
                                                処理2;
      end if;
 if
      if (条件式1) then
                                           if (条件式1)
          処理1;
                                                処理1 ;
      elsif (条件式2) then
                                           else if (条件式2)
          処理2;
                                               処理2;
      else
                                           else
         処理3 ;
                                               処理3;
      end if;
      case 信号名 is
                                           case (信号名)
       when (信号の値1 => 処理1;
                                             信号の値1:
                                                          処理1;
case
       when (信号の値2 => 処理2 ;
                                              信号の値2
                                                          処理2 ;
      when others = > 処理 n ;
                                            default:
                                                          処理n;
      end case;
                                           end case
```

| 項目   | VHDL                                                                              |        | Verilog-HDL                                                   |       |  |
|------|-----------------------------------------------------------------------------------|--------|---------------------------------------------------------------|-------|--|
|      | and, or, not, xor, nand, nor                                                      | (論理)   | &&,   , !                                                     | (論理)  |  |
| 演算子  |                                                                                   |        | &,  , -, ^, -&, - ,                                           | (ピット) |  |
|      | =, /=, >, <, >=, <=                                                               | (関係)   | ==, !=, >, <, >=, <=                                          | (関係)  |  |
|      | +, -, *, /, mod                                                                   | (算術)   | +, -, *, /, %                                                 | (算術)  |  |
|      | 信号名 & 信号名                                                                         | (連接)   | [ 信号名 , 「信号名 ]                                                | (連接)  |  |
| 階層設計 | component コンポーネント名 port (ポート名): モード型 end component; ラベル : コンポーネント名 port map (接続); | データ型); | module 上位のモジュール名 (ボートリスト ボート宣言 下位のモジュール名 ラベル (接続); end module |       |  |

## ▶ 付.3 Verilog-HDLのコード例

代表例として、10 秒カウンタ(138 ページ例題 5-1 参照)の Verilog-HDL コードをリスト付  $3\sim 6$  に示します。139 ページのリスト  $5.6\sim 5.9$  と比較してみるとよいでしょう。また、このコードでは、階層設計を行っていますので、この点からも VHDL と Verilog-HDL を比べてみましょう。

ISE WebPACK を使用して Verilog-HDL のコードを記述する場合には, ツールバーの「Project」 → 「New Source」を選択した際に, 「Verilog Module」を指定します (39 ページの図 2.15, 図 2.16 参照).

```
行
会
```

```
module watch10(CLK, RESET, DOUT);
 input CLK;
 input RESET;
 output [7:0] DOUT;
 wire CE TMP;
  wire [ 3:0] CNT_TMP;
divider22 C1(.CLK(CLK),.CEOUT(CE TMP));
counter10 C2(.CE(CE_TMP),.RESET(RESET),.CNT(CNT TMP));
decoder8 C3(.DIN(CNT TMP),.DOUT(DOUT));
endmodule
           リスト付3 階層設計用 (watch10) のコード
module divider22(CLK, CEOUT);
 input CLK;
 output CEOUT;
  reg CEOUT;
 reg [ 21:0] DD;
always @ (posedge CLK)
begin
DD <= DD+1'b1;
end
always @ (DD)
begin
        if (DD == 22'b1111 1111 1111 1111 1111 11)
                 CEOUT <= 1'b1;
        else
                 CEOUT <= 1'b0;
end
            リスト付4 分周回路 (divider2) のコード
module counter10(CE, RESET, CNT);
 input CE;
 input RESET;
 output [3:0] CNT;
 reg [3:0] CNT;
always @(posedge CE)
begin
       if (RESET == 1'b0)
              CNT <= 4'b0000;
        else if(CNT == 4'b1001)
                        CNT <= 4'b0000;
                else
                        CNT <= CNT +1'b1;
end
endmodule
```

リスト付5 カウンタ (counter10) のコード

リスト付6 デコーダ (decoder8) のコード

142 ページの表 5.3 に示したピン割り当てを行って HDL トレーナーで動作確認を行ってください。ただし、Verilog-HDL を使用してシミュレーションを行う場合には、MXE II Starter をVerilog-HDL用にインストールしてあることが必要です。

# **静** 答

### 演習問題解答

#### 第1章

- 1.1 CPU に与えるプログラムは CPU というハードウェア上での動作を示す命令であるが、CPLD/FPGA に与えるコードは CPLD/FPGA 内部を目的のハードウェアに仕立てる指示である。
- 1.2 ①, ④, ⑤
- 1.3 CPLD ①, ②, ④ FPGA ③, ⑤
- 1.4 VHDL
- 1.5 論理シミュレーションは実際の回路で生じる遅延の影響を考慮せずに行うが、遅延シミュレーションはそれを考慮する。
- 1.6 シミュレーションを行う場合に、回路に与える入力信号を記述したデータ、
- 1.7 HDLで記述したソースコードをディジタル回路に変換する.
- 1.8 論理合成によって生成された回路を、実際の CPLD/FPGA 内部でどのように構成するかを決め、ピン配置を行う。
- 1.9 作成したデータを CPLD/FPGA へ転送する.
- 1.10 ダウンロードする際の規格は JTAG または USB などを使用することができる。 JTAG の場合はパソコンの パラレルポート (プリンタポート)、USB の場合には USB ポートを使用する。
- 1.11 ①, ④, ⑤, ⑦, ⑧

JTAG を使用する場合において「ダウンロードケーブル」といった場合には、データ変換装置(電子回路)を含んだケーブルを指す。一方で、評価ボードの中にはこのデータ変換装置を搭載したものがある。このような評価ボードを用いる場合には、パソコンとは単純な(データ変換回路を含まない)ケーブルによって接続すればよい。

#### 第2章

- 2.1 規模。入出力ピン数、動作電圧、動作速度、パッケージ形状、価格など
- 2.2 CoolRunner XPLA3 ファミリの「XCR3128XL-VQ100C」が条件を満たす最小規模の CPLD となる。
- 2.3 高速で動作させるほど、消費電力は大きくなる。
- 2.4 ① 10 進数で 0 から 9 までをカウントする 4 ピットのカウンタ回路である。
  - ② 評価ボードに搭載されている 4 MHz の動作クロックを分周する 22 ビットのカウンタ回路である. 分周 回路の出力信号によって、10 進数カウンタ回路が、およそ 1 秒の周期で動作するようにしている。
  - ③ 10 進数カウンタ回路の出力は2 進数の 0000 から 1001 であるため、この出力データで7 セグメント LED を 10 進数表示できるようにデータ変換する回路である。
- **2.5** *CLK*: 外部から CPLD へ入力される 1 ビットのクロック信号 (4 MHz) である.
  - RESET: 外部から CPLD へ入力される 1 ビットのリセット信号 (ブッシュスイッチ) である。
  - LED: CPLD から外部 (7 セグメント LED) へ出力される 8 ピット (0~7) の表示信号である.
- 2.6 VHDLのコードが記述されたテキストファイルである。
- 2.7 56ページ図 2.46において、ファイル「LED10.npl」のアイコンをダブルクリックすればよい、
- 2.8 ① 配置配線から作業を行う. たとえば、51ページ図 2.37 において、ファイル「LED10.ucf」の内容を変更 すればよい。その後、配置配線を実行し、ダウンロードを行う。

(2)

表 2.8 変更後の入出力ピン

| 記号 |       | ピン番号 | 備考           |  |
|----|-------|------|--------------|--|
| 入力 | CLK   | 22   | セラロック 4 MHz  |  |
|    | RESET | 35   | プッシュスイッチ SW2 |  |
|    | LED0  | 74   |              |  |
|    | LED1  | 73   |              |  |
|    | LED2  | 72   |              |  |
| 出力 | LED3  | 71   | 7セグメント LED   |  |
| 力  | LED4  | 70   | LED3         |  |
|    | LED5  | 68   |              |  |
| -  | LED6  | 67   |              |  |
|    | LED7  | 64   |              |  |

③ 各自で実習を行うこと.

#### 第3章

- 3.1 ① 1ビットの論理データ型 ② 複数ビットの論理データ型, つまり「std\_logic」のベクトル型
- 3.2 シーケンシャル文は実行が順次行われるが、コンカレント文では同時に行われる。
- 3.3 センシティビティリストに記述した信号に変化があった場合、process 文中に記述した処理が実行される.
- 3.4 構造記述は回路図に基づいた記述を行うが、動作記述は真理値表などで表された動作を直接記述することができる。
- $\textbf{3.5} \quad \textcircled{1} \text{ in std\_logic} \qquad \textcircled{2} \text{ in std\_logic} \qquad \textcircled{3} \text{ in std\_logic} \qquad \textcircled{4} \text{ out std\_logic}$ 
  - 5 signal 6 begin 7 not 8 X or Y
- 3.6 case 文を用いたコード例をリスト 3.30 に示す。

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity syo3 6 is
   Port ( A : in std_logic_vector(2 downto 0);
         F : out std logic);
end syo3_6;
architecture Behavioral of syo3 6 is
begin
        process(A)
        begin
                case (A) is
                         when "000" \Rightarrow F <= '1';
                         when "111" => F <= '1';
                         when others => F <= '0';
                end case ;
        end process ;
end Behavioral;
```

リスト 3.30 3 ビット一致回路のコード (動作記述)

```
第4章
4.1 ① J&K ② CLK ③ '0' ④ RESET ⑤ '0' ⑥ case ⑦ not WORK
⑧ others ⑨ end case ⑩ WORK
4.2 library IEEE;
```

```
library IEEE;
use IEEE.STD LOGIC 1164.ALL;
use IEEE.STD LOGIC ARITH.ALL;
use IEEE.STD LOGIC UNSIGNED.ALL;
entity syo4 2 is
  Port ( CLK, RESET : in std_logic;
          Q : out std logic vector(1 downto 0));
end syo4 2;
architecture Behavioral of syo4 2 is
       signal WORK : std logic vector(1 downto 0);
begin
process (CLK)
begin
  if (CLK'event and CLK='1') then
                if (RESET = '0') then
                        WORK <= "00" ;
                else
                        WORK <= WORK + '1' ;
                end if ;
  end if;
end process;
O <= WORK ;
end Behavioral;
```

#### リスト 4.23 同期式 4 進カウンタのコード

```
4.3
        library IEEE;
        use IEEE.STD LOGIC 1164.ALL;
        use IEEE.STD LOGIC ARITH.ALL;
        use IEEE.STD LOGIC UNSIGNED.ALL;
        entity syo4 3 is
           Port ( CLK, RESET : in std logic;
                  Q : out std logic vector(3 downto 0));
        end syo4 3;
        architecture Behavioral of syo4_3 is
               signal WORK : std_logic_vector(3 downto 0);
        begin
        process (CLK)
        begin
          if (CLK'event and CLK='0') then
                        if ((RESET = '0') or (WORK = "1000")) then
                                 WORK <= "0000";
                        else
                                 WORK <= WORK + '1';
                   end if;
                end if:
        end process;
        Q <= WORK ;
        end Behavioral;
```

リスト 4.24 同期式 9 進カウンタのコード

```
解
答
```

```
4.4
        library IEEE;
        use IEEE.STD LOGIC 1164.ALL;
        use IEEE.STD_LOGIC_ARITH.ALL;
        use IEEE.STD_LOGIC UNSIGNED.ALL;
        entity syo4 4 is
           Port (CLK : in std_logic;
                 LED : out std_logic_vector(7 downto 0));
        end syo4 4;
        architecture Behavioral of syo4 4 is
                signal DD : std_logic_vector(21 downto 0) ;
                signal CE : std logic ;
                signal WORK : std_logic_vector(3 downto 0) ;
       begin
        -- 分周回路 22ビット
       process (CLK)
       begin
         if CLK'event and CLK='1' then
             DD <= DD + '1':
         end if;
       end process;
       process (DD)
       begin
         if DD = "11111111111111111111" then
            CE <= '1';
         else
            CE <= '0';
         end if;
       end process;
       -- カウンタ回路
       process (CE)
       begin
               if (CE'event and CE='0') then
                         if (WORK = "0111") then
                                 WORK <= "0000";
                                WORK <= WORK - '1';
                         end if ;
               end if;
       end process;
       --デコーダ回路
       process (WORK)
       begin
               case WORK is
                      when "0000" => LED <= "00000011"; --0
                      when "1111" => LED <= "00001001"; --9
                      when "1110" \Rightarrow LED \Leftarrow "00000001"; -8
                      when "1101" => LED <= "00011011"; --7
                      when "1100" \Rightarrow LED \Leftarrow "01000001"; --6
                      when "1011" \Rightarrow LED \Leftarrow "01001001"; --5
                      when "1010" => LED <= "10011001" ; --4
```

```
when "1001" => LED <= "00001101"; --3
       when "1000" => LED <= "00100101"; --2
       when "0111" => LED <= "10011111"; --1
       when others => null ;
end case;
```

end process; end Behavioral;

#### リスト 4.25 10 進ダウンカウンタ表示回路のコード

#### 第5章

- 5.1 ① entity ② component ③ end component ④ HA2\_CO (5) ha 6 A 7 S 8) HA1\_CO 

  9) C\_I 

  10) or 
  11) entity 
  12) ha 
  13) ha 
  14) xor 
  15) and
- 5.2 複雑な回路でも、モジュール単位に分割して考えることができる。また、何度も使用する機能は、モジュー ルとして1度記述しておけばよい.
- 5.3 130ページ図 5.5, 図 5.6参照

#### 第6章

- **6.1** ②, ③
- 6.2 リスト 6.7





- **6.3** ① '0' ② process ③ '1' ④ 10 ⑤ end process
- **6.4** 152 ページのリスト 6.2 と同様なテストベンチを作成して、VHDL で記述した半加算器(79 ページ例題 3-1 参照)をシミュレーションする.
- 6.5 162 ページのリスト 6.6 と同様なテストベンチを作成して、VHDL で記述した同期式 5 進カウンタ (120 ページリスト 4.16 参照) をシミュレーションする。

## 参考文献

- 1. ザイリンクス社の資料 (http://www.xilinx.co.jp/)
  - ・ CoolRunner-II CPLD ファミリ
  - ・ XC2C256: 256 マクロセル CoolRunner-II CPLD
  - · CPLD/CoolRunner 製品概要
  - · Spartan 製品概要
  - · 6.1i ソフトウェア マニュアル など多数
- 2. メメックジャパン社の資料 (http://www.memec.co.jp/)
  - · ISE6.1iJ インストールマニュアル
  - · ModelSim インストールガイド
  - · 2003 Xilinx and Memec Product Guid
  - ・トレーニング資料 (VHDL 初級・中級コース)
- 3. アルテラ社の資料 (http://www.altera.co.jp/index.html)
  - ・デザイン・ソフトウェア・セレクタ・ガイド
  - · Quartus II version 3.0 Software SP2 Release Notes
  - · Quartus II Software Quick Start Guide
  - · Introduction to Quartus II Manual
  - · Quartus II Installation & Licensing for PCs Manual
- 4. ソリトンウェーブ社の資料
  - HDLトレーナー (HDL-10) 取扱説明書
- 5. VHDLによるハードウェア設計入門 長谷川裕恭 CQ 出版社
- 6. VHDLによるディジタル回路入門 並木秀明, 永井亘道 技術評論社
- 7. VHDL, Verilog, AHDL によるデジタルシステム設計 原田豊 丸善
- 8. 入門 Verilog-HDL 記述 小林優 CQ 出版社
- 9. ディジタル電子回路の基礎 堀桂太郎 東京電機大学出版局



# 索引

FA 81 PIC マイコン 5 [英数] for 文 154 process 文 70 FPGA 8, 15 10 進カウンタ 121,161 FS 84 Quartus II 20, 177 10 秒カウンタ 204 Quartus II Web Edition 177 10 秒カウンタ回路 138 HA 79 100 秒カウンタ 143 HDL 9.17 RAM 16 2" 進カウンタ 119 HDL Bencher 154 RS-FF 102 5 進カウンタ 119 HDLコード記述 19 RTL Schematic 46 7 進カウンタ 119 HDL トレーナー 195 7セグメント LED 89 HS 83 SFL 18 8 進カウンタ 119 signal 文 67 i4004 4 SPARTAN 16 ABEL 18 if 文 71 SRAM 16 AHDL 18 implement Design 43 std logic 61, 64 AND/OR セレクタ回路 73 in 62 std\_logic\_vector 61, 64 AND 回路 60 inout 62 Synthesize 44 ASIC 7 1/0 ブロック 14 Synthesize Report 45 Assign Package Pins 49 ISE WebPACK 166 systemC 17 ISE WebPACK の起動 35 case 文 74 T-FF 107 CD-ROM 174 jed 57 TEXTIO 154 CLB 15 JK-FF 104 CLK 97 JTAG 14, 23 ucf 47, 57 CoolRunner 14 CoolRunner-II 14, 31 LUT 15 Verilog-HDL 10, 17, 201 CPLD 8, 13 Verilog-HDL □ - ド 204 CPLD/FPGA 8 MAX+PLUS II 20, 177 vhd 39, 57 CPU 4.12 ModelSim 20, 188 VHDL 10, 17 C言語 9,68 VIRTEX 16 NIC アドレス 181 D-FF 97 npl 57 WARNING 45, 123, 135, 141 DLL 16 null 76 when 75 n 進カウンタ 118,119 when others 75 EEPROM 14 else 72 out 62 XC9500 14 elsif 72

#### [和 文]

#### あ行

アカウントの作成 168 アーキテクチャ宣言 62 アルテラ社 20 一致回路 94 イネーブル端子 101 インタフェース 151 エラーメッセージ 44 エンコーダ 85 演算子 77 エンティティ宣言 61

#### か行

階層構造 138 階層設計 128, 204 開発ツール 21 回路 96 拡張キット 200 拡張子 39 カスケード接続 96 カスタム IC 7 機能宣言部 62,129 組合せ回路 59,79 繰り返し波形 153 グレード 28 クロック 97,111 構造記述 76 コード自動生成機能 42 コメント文 67 コンカレント 69,70 コンフィグレーション 16 コンフィグレーション用 ROM 16 コンポーネント宣言 129,132

#### さ行

ザイリンクス社 14 シーケンシャル 68,70 システムゲート 30 シフトレジスタ 109 シミュレーション 22,150,155 シミュレーションのスタート 159 シミュレータ 22 シミュレータの起動 157 周 期 111 周波数 124 順 次 68 順序回路 59,96 仕様設計 19 消費電力 32 シリアル 109 シリアルイン・パラレルアウト 110

スイッチマトリクス 14 スピード 28 スライス 15 セグメント記号 89 セラロック発振子 111 セレクタ 90 全加算器 81 全減算器 84,85,128 センシティビティリスト 70

ソリトンウェープ 200

信号宣言部 62,129

#### た行

代 入 62
タイムチャート 160
ダウンロード 16,19,53
ダウンロードケーブル 23
ダウンロードファイル 54
ダウンロードファイル作成 19
ターゲットデバイス 28
立ち上りエッジ 97
立ち下りエッジ 97
遅延シミュレーション 19
チャタリング 11,106,108,111
デコーダ 87
テストベンチ 22,150
テストベンチの記述 156

データ型 61,64

デマルチプレクサ 92

同期式 96 同期式カウンタ 118 同期リセット 99 動作記述 76 動作周波数 32 同 時 69 ド・モルガンの定理 64 トリガ 70

#### な行

内部信号 67 ネガティブエッジ 97 ノイズ 96

#### は行

配置配線 19.47.52 波形パターン 151 パスワード 168,189 パッケージ 29,60 ハードウェア記述言語 9.17 パラレル 109 パラレルイン・シリアルアウト 114 パラレルポート用ドライバ 186 半加算器 79 半減算器 83,131 汎用ロジック IC 4 非同期式 96 非同期リセット 35,99 ヒューマンデータ社 23 評価ボード 24.33 ピンの指定 47 ピン割り当て作業 49 ファンクションプロック 14 フィッティング 20 ブザー 124 不 定 93 フラッシュメモリ 14 フリップフロップ 96 負論理動作 74 分 周 124 分周回路 35,111

ベクトル 66 方形波 111 ポジティブエッジ 97 ポートマップ宣言 129,134,137

#### ま行

マクロセル 14,28 マルチプレクサ 90 メンターグラフィックス社 20 モジュール化 128 モード型 61

#### ゆ行

有限時間の波形 154 優先順位 62,77 ユーザ ID 168,189 ユーザ登録 168 予約語 77

**ら 行** ライセンスの取得 181,191 ライセンスの設定 184 ライセンスファイル 184 ライブラリ 60 ライブラリ宣言 60 ラッチ 96 ラベル名 70 レジストレーション ID 174 ロータリスイッチ 89 論理演算子 63 論理合成 19,44 論理シミュレーション 19

**わ 行** ワイヤード AND 14



#### 著者略歷

堀 桂太郎(ほり・けいたろう) 日本大学大学院 理工学研究科 博士後期課程 情報科学専攻修了 博士 (工学)

現在 国立明石工業高等専門学校 電気情報工学科 助教授

#### <主な著書>

図解 PIC マイコン実習 (森北出版) H8マイコン入門(東京電機大学出版局) ディジタル電子回路の基礎(東京電機大学出版局) アナログ電子回路の基礎 (東京電機大学出版局) 絵ときディジタル回路入門早わかり (オーム社) など

図解 VHDL 実習 ―ゼロからわかるハードウェア記述言語― © 堀 桂太郎 2004

2004年4月15日 第1版第1刷発行 【本書の無断転載を禁ず】

者 堀 桂太郎 著

発 行 者 森北 肇

発 行 所 森北出版株式会社

東京都千代田区富士見 1-4-11 (〒 102-0071) 電話 03-3265-8341 / FAX 03-3264-8709

http://www.morikita.co.jp/

日本書籍出版協会・自然科学書協会・工学書協会 会員 | C(株) 日本著作出版権管理システム委託出版物>

落丁・乱丁本はお取替えいたします 印刷/双文社印刷所・製本/協栄製本

Printed in Japan / ISBN4-627-78391-4

```
雷気数学
                          鳥居·藤川·伊藤 著 A5/184頁 2003年刊
電気回路の基礎と演習
                       高田·坂·井上·愛知 著 A5/184頁 2000年刊
見てわかる 半導体の基礎
                              高橋 清 著 A5/160頁 2000年刊
電子工学とトランジスタ (数式処理ソフトMathcad 演習付き) 臼田・奥田 著 A5/120頁 1999年刊
理工学のための電磁気学入門
                             高村秀一著 A5/208頁 2002年刊
メタ雷磁気学
                             細野敏夫 著 菊/264頁 1999年刊
電気磁気学〈その物理像と詳論〉
                             小塚洋司 著 菊/352頁 1998年刊
光と電波(電磁波に学ぶ自然との対話)
                              徳丸 仁 著 菊/224頁 2000年刊
電波のかたち
                              徳丸 仁 著 A5/176頁 2003年刊
高周波領域における 材料定数測定法
                             橋本修 著 A5/200頁 2003年刊
光エレクトロニクスの基礎 桜庭 郎・高井信勝・三島瑛人 著 A5/176頁 2001年刊
オプトメカトロニクス (光情報システムの基礎) 浮田宏生 著 A5/176頁 2001年刊
マイクロメカニカルフォトニクス (光情報システムの応用) 浮田宏生 著 A5/208頁 2002年刊
半導体デバイス工学 (デバイスの基礎から製造技術まで) 大山英典・葉山清輝 著 A5/176頁 2004年刊
電子デバイスの基礎
                        桜庭一郎・岡本 淳 著 菊/192頁 2003年刊
トランジスタの基礎〈工学基礎のための電子回路1〉
                             池田哲夫 著 A5/224頁 1998年刊
集積回路の基礎と応用〈エ学基礎のための電子回路2〉池田哲夫 監修 A5/264頁 2001年刊
ディジタル基本回路入門
                        岡野大祐·松本欣也 著 A5/128頁 1999年刊
ディジタル信号処理の基礎
                              兼田 護 著 A5/144頁 2000年刊
DSPによる
ディジタル信号処理プログラミング入門 ( いた実践学習 ) 三谷・有井 著 B5/160頁 2000年刊
図解PICマイコン実習〈ゼロからわかる電子制御〉
                             堀 桂太郎 著 B5/208頁 2003年刊
Spiceを使った電子回路設計工学 黒瀬能車・岡田和之 著 A5/184頁 2002年刊
プリント基板設計の基礎と応用 〈CAD を用いた実装設計
                            〉小島東作 著 B5/160頁 2003年刊
自然観測法の理論〈瞬時性に着目した新しい波形解析法〉
                             飯島泰蔵 著 A5/208頁 2000年刊
ディジタル自然観測法〈時系列解析のための新しい理論〉
                             飯島泰蔵 著 A5/152頁 2001年刊
光情報処理の基礎と応用 光信号処理 光コンピューティング 松下・宮崎 著 菊 /404頁 1998年刊
Mathcadによる光システムの基礎
                        小関 健·原田 ·成 著 B5/176頁 1999年刊
電子材料(基礎から光機能材料まで)
                              澤岡 昭 著 A5/176頁 1999年刊
希土類永久磁石
                         俵 好夫·大橋 健 著 A5/192頁 1999年刊
実用電気機器学
                             森安正司 著 A5/240頁 2000年刊
磁界系有限要素法を用いた最適化
                             高橋則雄 著 A5/240頁 2001年刊
最新有限要素法による電気・電子機器のCAE
                           伊藤·河瀬 著 A5/176頁 2000年刊
制御工学〈フィードバック制御の考え方〉
                         斉藤制海·徐 粒 著 A5/240頁 2002年刊
演習で学ぶ現代制御理論
                             森 泰親 著 A5/192頁 2003年刊
センサの原理と応用
                             塩山忠義 著 A5/192頁 2002年刊
Matlabの総合応用(例題による解説)
                             高谷邦夫 著 菊/264頁 2002年刊
```



# 図解 PIC マイコン実習

# ゼロからわかる電子制御

堀 桂太郎/著

B5 判・208 頁・定価 2310 円⑤

初めて PIC を学習しようとする方々を 対象に、PIC の中でも特に扱いやすい 16F84A を選び、その原理と使い方を例 題や演習問題をまじえてやさしく解説.

■目次 マイコン制御の基礎/PIC マイコンの基礎/マイコンでのデータ表現/アセンブラ言語/プログラミング実習/MPLABの使い方/付録

[ISBN4-627-78331-0]

インターネットで書籍を検索・注文できます. http://www.morikita.co.jp/ 価格は予告なく変更される場合があります. ISBN4-627-78391-4 C3054 ¥2600E 定価(本体2600円+税)





